summaryrefslogtreecommitdiff
path: root/inc/builder/type/footer/button
diff options
context:
space:
mode:
authorZach van Rijn <me@zv.io>2021-07-21 14:54:07 -0500
committerZach van Rijn <me@zv.io>2021-07-21 14:54:07 -0500
commit9d4123cee1867ee7199b06bdc92d40611f547ecc (patch)
tree6d864e2725242863afed1f8ba12d9c7a9bc63a69 /inc/builder/type/footer/button
downloadblog-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')
-rw-r--r--inc/builder/type/footer/button/assets/js/minified/customizer-preview.min.js1
-rw-r--r--inc/builder/type/footer/button/assets/js/unminified/customizer-preview.js15
-rw-r--r--inc/builder/type/footer/button/class-astra-footer-button-component-loader.php62
-rw-r--r--inc/builder/type/footer/button/class-astra-footer-button-component.php46
-rw-r--r--inc/builder/type/footer/button/dynamic-css/dynamic.css.php90
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;
+}