laipower/wp-content/plugins/gp-premium/elements/class-metabox.php

2246 lines
100 KiB
PHP

<?php
/**
* This file builds all the options for our Elements.
*
* @package GP Premium
*/
if ( ! defined( 'ABSPATH' ) ) {
exit; // No direct access, please.
}
/**
* Start our Elements metabox class.
*/
class GeneratePress_Elements_Metabox {
/**
* Instance.
*
* @since 1.7
*
* @var instance
*/
private static $instance;
/**
* Initiator
*
* @since 1.7
*/
public static function get_instance() {
if ( ! isset( self::$instance ) ) {
self::$instance = new self();
}
return self::$instance;
}
/**
* Build it.
*
* @since 1.7
*/
public function __construct() {
add_action( 'admin_body_class', array( $this, 'body_class' ) );
add_action( 'admin_enqueue_scripts', array( $this, 'scripts' ) );
add_action( 'add_meta_boxes', array( $this, 'register_metabox' ) );
add_action( 'save_post', array( $this, 'save' ) );
add_action( 'wp_ajax_generate_elements_get_location_terms', array( $this, 'get_terms' ) );
add_action( 'wp_ajax_generate_elements_get_location_posts', array( $this, 'get_posts' ) );
add_action( 'wp_ajax_generate_elements_get_location_objects', array( $this, 'get_all_objects' ) );
}
/**
* Check the current element type.
*
* @since 1.11.0
*/
public static function get_element_type() {
$element_type = get_post_meta( get_the_ID(), '_generate_element_type', true );
if ( ! $element_type && isset( $_GET['element_type'] ) ) { // phpcs:ignore -- No processing happening.
$element_type = esc_html( $_GET['element_type'] ); // phpcs:ignore -- No processing happening.
}
if ( ! $element_type ) {
$element_type = 'no-element-type';
if ( function_exists( 'get_current_screen' ) ) {
$current_screen = get_current_screen();
if ( ! empty( $current_screen->is_block_editor ) ) {
$element_type = 'block';
}
}
}
return $element_type;
}
/**
* Add a body class if we're using the Header element type.
* We do this so we can hide the Template Tags metabox for other types.
*
* @since 1.7
*
* @param string $classes Existing classes.
* @return string
*/
public function body_class( $classes ) {
if ( 'gp_elements' === get_post_type() ) {
$element_type = self::get_element_type();
if ( $element_type ) {
$classes .= ' ' . $element_type . '-element-type';
} else {
$classes .= ' no-element-type';
}
if ( 'header' === $element_type && get_post_meta( get_the_ID(), '_generate_element_content', true ) ) {
$classes .= ' element-has-page-hero';
}
$block_type = get_post_meta( get_the_ID(), '_generate_block_type', true );
if ( $block_type ) {
if ( 'content-template' === $block_type && get_post_meta( get_the_ID(), '_generate_use_theme_post_container', true ) ) {
$classes .= ' using-theme-post-container';
}
if ( ( 'archive-navigation-template' === $block_type || 'post-navigation-template' === $block_type ) && get_post_meta( get_the_ID(), '_generate_use_archive_navigation_container', true ) ) {
$classes .= ' using-theme-pagination-container';
}
$classes .= ' ' . $block_type . '-block-type';
}
}
return $classes;
}
/**
* Enqueue any necessary scripts and styles.
*
* @since 1.7
*
* @param string $hook The current page hook.
*/
public function scripts( $hook ) {
if ( in_array( $hook, array( 'post.php', 'post-new.php' ) ) ) {
if ( 'gp_elements' === get_post_type() ) {
$element_type = get_post_meta( get_the_ID(), '_generate_element_type', true );
// Remove autosave when dealing with non-content Elements.
// phpcs:ignore -- No data processing happening.
if ( 'block' !== $element_type || ( isset( $_GET['element_type'] ) && 'block' !== $_GET['element_type'] ) ) {
wp_dequeue_script( 'autosave' );
}
$deps = array( 'jquery' );
if ( function_exists( 'wp_enqueue_code_editor' ) ) {
$settings = wp_enqueue_code_editor(
array(
'type' => 'application/x-httpd-php',
'codemirror' => array(
'indentUnit' => 2,
'tabSize' => 2,
),
)
);
$deps[] = 'code-editor';
} else {
$settings = false;
}
$element_type = self::get_element_type();
wp_enqueue_script( 'generate-elements-metabox', plugin_dir_url( __FILE__ ) . 'assets/admin/metabox.js', $deps, GP_PREMIUM_VERSION, true );
wp_localize_script(
'generate-elements-metabox',
'elements',
array(
'nonce' => wp_create_nonce( 'generate-elements-location' ),
'settings' => $settings ? wp_json_encode( $settings ) : false,
'type' => $element_type,
'custom_image' => __( 'Custom Image', 'gp-premium' ),
'fallback_image' => __( 'Fallback Image', 'gp-premium' ),
'choose' => __( 'Choose...', 'gp-premium' ),
'showID' => apply_filters( 'generate_elements_show_object_ids', false ),
)
);
wp_enqueue_style( 'generate-elements-metabox', plugin_dir_url( __FILE__ ) . 'assets/admin/metabox.css', array(), GP_PREMIUM_VERSION );
wp_enqueue_style( 'generate-elements-balloon', plugin_dir_url( __FILE__ ) . 'assets/admin/balloon.css', array(), GP_PREMIUM_VERSION );
wp_enqueue_media();
wp_enqueue_script( 'wp-color-picker' );
wp_enqueue_style( 'wp-color-picker' );
wp_enqueue_script( 'wp-color-picker-alpha', GP_LIBRARY_DIRECTORY_URL . 'alpha-color-picker/wp-color-picker-alpha.min.js', array( 'wp-color-picker' ), '3.0.0', true );
wp_add_inline_script(
'wp-color-picker-alpha',
'jQuery( function() { jQuery( ".color-picker" ).wpColorPicker(); } );'
);
if ( function_exists( 'wp_add_inline_script' ) && function_exists( 'generate_get_default_color_palettes' ) ) {
// Grab our palette array and turn it into JS.
$palettes = wp_json_encode( generate_get_default_color_palettes() );
// Add our custom palettes.
// json_encode takes care of escaping.
wp_add_inline_script( 'wp-color-picker', 'jQuery.wp.wpColorPicker.prototype.options.palettes = ' . $palettes . ';' );
}
wp_enqueue_style( 'select2', GP_LIBRARY_DIRECTORY_URL . 'select2/select2.min.css', array(), '4.0.13' );
wp_enqueue_script( 'select2', GP_LIBRARY_DIRECTORY_URL . 'select2/select2.full.min.js', array( 'jquery', 'generate-elements-metabox' ), '4.0.13', true );
$css = '';
if ( function_exists( 'generate_get_option' ) && 'separate-containers' === generate_get_option( 'content_layout_setting' ) ) {
$css .= 'body.left-sidebar-block-type .block-editor-block-list__layout.is-root-container, body.right-sidebar-block-type .block-editor-block-list__layout.is-root-container {background: ' . generate_get_option( 'background_color' ) . ';}';
$css .= 'body.content-template-block-type:not(.using-theme-post-container) .block-editor-block-list__layout.is-root-container, body.archive-navigation-template-block-type:not(.using-theme-pagination-container) .block-editor-block-list__layout.is-root-container {background: ' . generate_get_option( 'background_color' ) . ';}';
}
wp_add_inline_style( 'generate-elements-metabox', $css );
}
}
}
/**
* Register our metabox.
*
* @since 1.7
*/
public function register_metabox() {
// Title not translated on purpose.
add_meta_box( 'generate_premium_elements', 'Element', array( $this, 'element_fields' ), 'gp_elements', 'normal', 'high' );
add_meta_box( 'generate_page_hero_template_tags', __( 'Template Tags', 'gp-premium' ), array( $this, 'template_tags' ), 'gp_elements', 'side', 'low' );
remove_meta_box( 'slugdiv', 'gp_elements', 'normal' );
}
/**
* Output all of our metabox fields.
*
* @since 1.7
*
* @param object $post Our post object.
*/
public function element_fields( $post ) {
wp_nonce_field( basename( __FILE__ ), 'generate_elements_nonce' );
$type = self::get_element_type();
$page_hero_class = '';
$merge = get_post_meta( get_the_ID(), '_generate_site_header_merge', true );
$conditions_set = get_post_meta( get_the_ID(), '_generate_element_display_conditions', true );
$post_status = get_post_status( get_the_ID() );
if ( 'header' === $type && get_post_meta( get_the_ID(), '_generate_element_content', true ) ) {
$page_hero_class = ' has-page-hero';
}
?>
<div class="gp-element-type" style="display: none;">
<select class="select-type" name="_generate_element_type">
<option <?php selected( $type, '' ); ?> value=""><?php esc_attr_e( 'Choose...', 'gp-premium' ); ?></option>
<option <?php selected( $type, 'block' ); ?> value="block"><?php esc_attr_e( 'Block', 'gp-premium' ); ?></option>
<option <?php selected( $type, 'header' ); ?> value="header"><?php esc_attr_e( 'Header', 'gp-premium' ); ?></option>
<option <?php selected( $type, 'hook' ); ?> value="hook"><?php esc_attr_e( 'Hook', 'gp-premium' ); ?></option>
<option <?php selected( $type, 'layout' ); ?> value="layout"><?php esc_attr_e( 'Layout', 'gp-premium' ); ?></option>
</select>
</div>
<?php if ( 'publish' === $post_status && ! $conditions_set && 'block' !== $type ) : ?>
<div class="error notice inline elements-no-location-error" style="margin: 5px 0 10px;">
<p><?php _e( 'This element needs a location set within the Display Rules tab in order to display.', 'gp-premium' ); ?></p>
</div>
<?php endif; ?>
<div class="element-settings <?php echo esc_html( $type . $page_hero_class ); ?>">
<?php if ( 'hook' === $type || 'header' === $type ) : ?>
<textarea id="generate-element-content" name="_generate_element_content"><?php echo esc_textarea( get_post_meta( get_the_ID(), '_generate_element_content', true ) ); ?></textarea>
<?php endif; ?>
<ul class="element-metabox-tabs">
<?php if ( 'header' === $type ) : ?>
<li data-type="header" <?php echo 'header' === $type && '' === $page_hero_class ? 'class="is-selected" ' : ''; ?>data-tab="site-header">
<a href="#">
<?php _e( 'Site Header', 'gp-premium' ); ?>
</a>
</li>
<li data-type="header" <?php echo 'header' === $type && '' !== $page_hero_class ? 'class="is-selected" ' : ''; ?>data-tab="hero">
<a href="#">
<?php _e( 'Page Hero', 'gp-premium' ); ?>
</a>
</li>
<?php endif; ?>
<li data-type="hook" <?php echo ( 'hook' === $type || 'block' === $type ) ? 'class="is-selected" ' : ''; ?>data-tab="hook-settings">
<a href="#">
<?php echo 'block' === $type ? esc_attr__( 'Display Rules', 'gp-premium' ) : esc_attr__( 'Settings', 'gp-premium' ); ?>
</a>
</li>
<?php if ( 'layout' === $type ) : ?>
<li data-type="layout" <?php echo 'layout' === $type ? 'class="is-selected" ' : ''; ?>data-tab="sidebars">
<a href="#">
<?php _e( 'Sidebar', 'gp-premium' ); ?>
</a>
</li>
<li data-type="layout" data-tab="footer-widgets">
<a href="#">
<?php _e( 'Footer', 'gp-premium' ); ?>
</a>
</li>
<?php if ( function_exists( 'generate_disable_elements' ) ) : ?>
<li data-type="layout" data-tab="disable-elements">
<a href="#">
<?php _e( 'Disable Elements', 'gp-premium' ); ?>
</a>
</li>
<?php endif; ?>
<li data-type="layout" data-tab="content">
<a href="#">
<?php _e( 'Content', 'gp-premium' ); ?>
</a>
</li>
<?php endif; ?>
<?php if ( 'block' !== $type ) : ?>
<li data-tab="display-rules">
<a href="#">
<?php _e( 'Display Rules', 'gp-premium' ); ?>
</a>
</li>
<?php endif; ?>
<li data-type="all" data-tab="internal-notes">
<a href="#">
<?php _e( 'Internal Notes', 'gp-premium' ); ?>
</a>
</li>
</ul>
<table class="generate-elements-settings" data-type="hook" data-tab="hook-settings">
<tbody>
<?php
if ( 'hook' === $type ) :
?>
<tr id="hook-row" class="generate-element-row hook-row <?php echo '' !== get_post_meta( get_the_ID(), '_generate_block_type', true ) && 'hook' !== get_post_meta( get_the_ID(), '_generate_block_type', true ) ? 'hide-hook-row' : ''; ?>">
<td class="generate-element-row-heading">
<label for="_generate_hook"><?php _e( 'Hook', 'gp-premium' ); ?></label>
</td>
<td class="generate-element-row-content">
<select id="_generate_hook" name="_generate_hook">
<?php
$hooks = self::get_available_hooks();
foreach ( (array) $hooks as $group => $data ) {
?>
<optgroup label="<?php echo esc_html( $data['group'] ); ?>">
<?php
foreach ( $data['hooks'] as $val ) {
printf(
'<option value="%1$s" %2$s>%1$s</option>',
esc_html( $val ),
selected( get_post_meta( get_the_ID(), '_generate_hook', true ), $val )
);
}
?>
</optgroup>
<?php
}
?>
<optgroup label="<?php esc_attr_e( 'Custom', 'gp-premium' ); ?>">
<option <?php selected( get_post_meta( get_the_ID(), '_generate_hook', true ), 'custom' ); ?> value="custom"><?php esc_attr_e( 'Custom Hook', 'gp-premium' ); ?></option>
</optgroup>
</select>
</td>
</tr>
<tr class="generate-element-row custom-hook-name hook-row <?php echo '' !== get_post_meta( get_the_ID(), '_generate_block_type', true ) && 'hook' !== get_post_meta( get_the_ID(), '_generate_block_type', true ) ? 'hide-hook-row' : ''; ?>" <?php echo 'custom' !== get_post_meta( get_the_ID(), '_generate_hook', true ) ? 'style="display: none;"' : ''; ?>>
<td class="generate-element-row-heading">
<label for="_generate_custom_hook"><?php _e( 'Custom Hook Name', 'gp-premium' ); ?></label>
</td>
<td class="generate-element-row-content">
<input type="text" name="_generate_custom_hook" id="_generate_custom_hook" value="<?php echo esc_attr( get_post_meta( get_the_ID(), '_generate_custom_hook', true ) ); ?>" />
</td>
</tr>
<?php
endif;
if ( 'hook' === $type ) :
?>
<tr class="generate-element-row disable-header-hook" <?php echo 'generate_header' !== get_post_meta( get_the_ID(), '_generate_hook', true ) ? 'style="display: none;"' : ''; ?>>
<td class="generate-element-row-heading">
<label for="_generate_hook_disable_site_header"><?php _e( 'Disable Site Header', 'gp-premium' ); ?></label>
</td>
<td class="generate-element-row-content">
<input type="checkbox" id="_generate_hook_disable_site_header" name="_generate_hook_disable_site_header" value="true" <?php checked( get_post_meta( get_the_ID(), '_generate_hook_disable_site_header', true ), 'true' ); ?> />
</td>
</tr>
<tr class="generate-element-row disable-footer-hook" <?php echo 'generate_footer' !== get_post_meta( get_the_ID(), '_generate_hook', true ) ? 'style="display: none;"' : ''; ?>>
<td class="generate-element-row-heading">
<label for="_generate_hook_disable_site_footer"><?php _e( 'Disable Site Footer', 'gp-premium' ); ?></label>
</td>
<td class="generate-element-row-content">
<input type="checkbox" id="_generate_hook_disable_site_footer" name="_generate_hook_disable_site_footer" value="true" <?php checked( get_post_meta( get_the_ID(), '_generate_hook_disable_site_footer', true ), 'true' ); ?> />
</td>
</tr>
<tr class="generate-element-row">
<td class="generate-element-row-heading">
<label for="_generate_hook_execute_shortcodes"><?php _e( 'Execute Shortcodes', 'gp-premium' ); ?></label>
</td>
<td class="generate-element-row-content">
<input type="checkbox" id="_generate_hook_execute_shortcodes" name="_generate_hook_execute_shortcodes" value="true" <?php checked( get_post_meta( get_the_ID(), '_generate_hook_execute_shortcodes', true ), 'true' ); ?> />
</td>
</tr>
<tr class="generate-element-row">
<td class="generate-element-row-heading">
<label for="_generate_hook_execute_php"><?php _e( 'Execute PHP', 'gp-premium' ); ?></label>
</td>
<td class="generate-element-row-content">
<?php if ( ! GeneratePress_Elements_Helper::should_execute_php() ) : ?>
<?php
printf(
/* translators: %s is DISALLOW_FILE_EDIT constant */
esc_html__( 'Unable to execute PHP as %s is defined.', 'gp-premium' ),
'<code>DISALLOW_FILE_EDIT</code>'
);
?>
<?php else : ?>
<input type="checkbox" id="_generate_hook_execute_php" name="_generate_hook_execute_php" value="true" <?php checked( get_post_meta( get_the_ID(), '_generate_hook_execute_php', true ), 'true' ); ?> />
<?php endif; ?>
</td>
</tr>
<?php
endif;
if ( 'hook' === $type ) :
?>
<tr class="generate-element-row hook-row <?php echo '' !== get_post_meta( get_the_ID(), '_generate_block_type', true ) && 'hook' !== get_post_meta( get_the_ID(), '_generate_block_type', true ) ? 'hide-hook-row' : ''; ?>">
<td class="generate-element-row-heading">
<label for="_generate_hook_priority"><?php _e( 'Priority', 'gp-premium' ); ?></label>
</td>
<td class="generate-element-row-content">
<input type="number" id="_generate_hook_priority" name="_generate_hook_priority" placeholder="10" value="<?php echo esc_attr( get_post_meta( get_the_ID(), '_generate_hook_priority', true ) ); ?>" />
</td>
</tr>
<?php
endif;
?>
</tbody>
</table>
<?php if ( 'header' === $type ) : ?>
<table class="generate-elements-settings" data-type="header" data-tab="hero">
<tbody>
<tr class="generate-element-row">
<td class="generate-element-row-heading">
<label for="_generate_hero_custom_classes"><?php _e( 'Element Classes', 'gp-premium' ); ?></label>
<span class="tip" data-balloon="<?php esc_attr_e( 'Add custom classes to the Page Hero element.', 'gp-premium' ); ?>" data-balloon-pos="down">?</span>
</td>
<td class="generate-element-row-content">
<input type="text" name="_generate_hero_custom_classes" id="_generate_hero_custom_classes" value="<?php echo esc_attr( get_post_meta( get_the_ID(), '_generate_hero_custom_classes', true ) ); ?>" />
</td>
</tr>
<tr class="generate-element-row">
<td class="generate-element-row-heading">
<label for="_generate_hero_container"><?php _e( 'Container', 'gp-premium' ); ?></label>
</td>
<td class="generate-element-row-content">
<select id="_generate_hero_container" name="_generate_hero_container">
<option <?php selected( get_post_meta( get_the_ID(), '_generate_hero_container', true ), '' ); ?> value=""><?php esc_attr_e( 'Full Width', 'gp-premium' ); ?></option>
<option <?php selected( get_post_meta( get_the_ID(), '_generate_hero_container', true ), 'contained' ); ?> value="contained"><?php echo esc_attr_x( 'Contained', 'Width', 'gp-premium' ); ?></option>
</select>
</td>
</tr>
<tr class="generate-element-row">
<td class="generate-element-row-heading">
<label for="_generate_hero_inner_container"><?php _e( 'Inner Container', 'gp-premium' ); ?></label>
</td>
<td class="generate-element-row-content">
<select id="_generate_hero_inner_container" name="_generate_hero_inner_container">
<option <?php selected( get_post_meta( get_the_ID(), '_generate_hero_inner_container', true ), '' ); ?> value=""><?php echo esc_attr_x( 'Contained', 'Width', 'gp-premium' ); ?></option>
<option <?php selected( get_post_meta( get_the_ID(), '_generate_hero_inner_container', true ), 'full-width' ); ?> value="full-width"><?php esc_attr_e( 'Full Width', 'gp-premium' ); ?></option>
</select>
</td>
</tr>
<tr class="generate-element-row">
<td class="generate-element-row-heading">
<label for="_generate_hero_horizontal_alignment"><?php _e( 'Horizontal Alignment', 'gp-premium' ); ?></label>
</td>
<td class="generate-element-row-content">
<select id="_generate_hero_horizontal_alignment" name="_generate_hero_horizontal_alignment">
<option <?php selected( get_post_meta( get_the_ID(), '_generate_hero_horizontal_alignment', true ), '' ); ?> value=""><?php esc_attr_e( 'Left', 'gp-premium' ); ?></option>
<option <?php selected( get_post_meta( get_the_ID(), '_generate_hero_horizontal_alignment', true ), 'center' ); ?> value="center"><?php esc_attr_e( 'Center', 'gp-premium' ); ?></option>
<option <?php selected( get_post_meta( get_the_ID(), '_generate_hero_horizontal_alignment', true ), 'right' ); ?> value="right"><?php esc_attr_e( 'Right', 'gp-premium' ); ?></option>
</select>
</td>
</tr>
<tr class="generate-element-row requires-header-merge" <?php echo ! $merge ? 'style="display: none;"' : ''; ?>>
<td class="generate-element-row-heading">
<label for="_generate_hero_full_screen"><?php _e( 'Full Screen', 'gp-premium' ); ?></label>
</td>
<td class="generate-element-row-content">
<input type="checkbox" name="_generate_hero_full_screen" id="_generate_hero_full_screen" value="true" <?php checked( get_post_meta( get_the_ID(), '_generate_hero_full_screen', true ), 'true' ); ?> />
</td>
</tr>
<tr class="generate-element-row requires-full-screen" <?php echo ! $merge || ! get_post_meta( get_the_ID(), '_generate_hero_full_screen', true ) ? 'style="display: none;"' : ''; ?>>
<td class="generate-element-row-heading">
<label for="_generate_hero_vertical_alignment"><?php _e( 'Vertical Alignment', 'gp-premium' ); ?></label>
</td>
<td class="generate-element-row-content">
<select id="_generate_hero_vertical_alignment" name="_generate_hero_vertical_alignment">
<option <?php selected( get_post_meta( get_the_ID(), '_generate_hero_vertical_alignment', true ), '' ); ?> value=""><?php esc_attr_e( 'Top', 'gp-premium' ); ?></option>
<option <?php selected( get_post_meta( get_the_ID(), '_generate_hero_vertical_alignment', true ), 'center' ); ?> value="center"><?php esc_attr_e( 'Center', 'gp-premium' ); ?></option>
<option <?php selected( get_post_meta( get_the_ID(), '_generate_hero_vertical_alignment', true ), 'bottom' ); ?> value="bottom"><?php esc_attr_e( 'Bottom', 'gp-premium' ); ?></option>
</select>
</td>
</tr>
<tr class="generate-element-row">
<td class="generate-element-row-heading">
<label for="_generate_hero_padding"><?php _e( 'Padding', 'gp-premium' ); ?></label>
</td>
<td class="generate-element-row-content">
<div class="responsive-controls">
<a href="#" class="is-selected" data-control="desktop"><span class="dashicons dashicons-desktop"></span></a>
<a href="#" data-control="mobile"><span class="dashicons dashicons-smartphone"></span></a>
</div>
<div class="padding-container desktop">
<div class="padding-element">
<div class="padding-element-options">
<input type="number" id="_generate_hero_padding_top" name="_generate_hero_padding_top" value="<?php echo esc_attr( get_post_meta( get_the_ID(), '_generate_hero_padding_top', true ) ); ?>" />
<select id="_generate_hero_padding_top_unit" name="_generate_hero_padding_top_unit">
<option <?php selected( get_post_meta( get_the_ID(), '_generate_hero_padding_top_unit', true ), '' ); ?> value="">px</option>
<option <?php selected( get_post_meta( get_the_ID(), '_generate_hero_padding_top_unit', true ), '%' ); ?> value="%">%</option>
</select>
</div>
<span><?php esc_html_e( 'Top', 'gp-premium' ); ?></span>
</div>
<div class="padding-element">
<div class="padding-element-options">
<input type="number" id="_generate_hero_padding_right" name="_generate_hero_padding_right" value="<?php echo esc_attr( get_post_meta( get_the_ID(), '_generate_hero_padding_right', true ) ); ?>" />
<select id="_generate_hero_padding_right_unit" name="_generate_hero_padding_right_unit">
<option <?php selected( get_post_meta( get_the_ID(), '_generate_hero_padding_right_unit', true ), '' ); ?> value="">px</option>
<option <?php selected( get_post_meta( get_the_ID(), '_generate_hero_padding_right_unit', true ), '%' ); ?> value="%">%</option>
</select>
</div>
<span><?php esc_html_e( 'Right', 'gp-premium' ); ?></span>
</div>
<div class="padding-element">
<div class="padding-element-options">
<input type="number" id="_generate_hero_padding_bottom" name="_generate_hero_padding_bottom" value="<?php echo esc_attr( get_post_meta( get_the_ID(), '_generate_hero_padding_bottom', true ) ); ?>" />
<select id="_generate_hero_padding_bottom_unit" name="_generate_hero_padding_bottom_unit">
<option <?php selected( get_post_meta( get_the_ID(), '_generate_hero_padding_bottom_unit', true ), '' ); ?> value="">px</option>
<option <?php selected( get_post_meta( get_the_ID(), '_generate_hero_padding_bottom_unit', true ), '%' ); ?> value="%">%</option>
</select>
</div>
<span><?php esc_html_e( 'Bottom', 'gp-premium' ); ?></span>
</div>
<div class="padding-element">
<div class="padding-element-options">
<input type="number" id="_generate_hero_padding_left" name="_generate_hero_padding_left" value="<?php echo esc_attr( get_post_meta( get_the_ID(), '_generate_hero_padding_left', true ) ); ?>" />
<select id="_generate_hero_padding_left_unit" name="_generate_hero_padding_left_unit">
<option <?php selected( get_post_meta( get_the_ID(), '_generate_hero_padding_left_unit', true ), '' ); ?> value="">px</option>
<option <?php selected( get_post_meta( get_the_ID(), '_generate_hero_padding_left_unit', true ), '%' ); ?> value="%">%</option>
</select>
</div>
<span><?php esc_html_e( 'Left', 'gp-premium' ); ?></span>
</div>
</div>
<div class="padding-container mobile" style="display: none;">
<div class="padding-element">
<div class="padding-element-options">
<input type="number" id="_generate_hero_padding_top_mobile" name="_generate_hero_padding_top_mobile" value="<?php echo esc_attr( get_post_meta( get_the_ID(), '_generate_hero_padding_top_mobile', true ) ); ?>" />
<select id="_generate_hero_padding_top_unit_mobile" name="_generate_hero_padding_top_unit_mobile">
<option <?php selected( get_post_meta( get_the_ID(), '_generate_hero_padding_top_unit_mobile', true ), '' ); ?> value="">px</option>
<option <?php selected( get_post_meta( get_the_ID(), '_generate_hero_padding_top_unit_mobile', true ), '%' ); ?> value="%">%</option>
</select>
</div>
<span><?php esc_html_e( 'Top', 'gp-premium' ); ?></span>
</div>
<div class="padding-element">
<div class="padding-element-options">
<input type="number" id="_generate_hero_padding_right_mobile" name="_generate_hero_padding_right_mobile" value="<?php echo esc_attr( get_post_meta( get_the_ID(), '_generate_hero_padding_right_mobile', true ) ); ?>" />
<select id="_generate_hero_padding_right_unit_mobile" name="_generate_hero_padding_right_unit_mobile">
<option <?php selected( get_post_meta( get_the_ID(), '_generate_hero_padding_right_unit_mobile', true ), '' ); ?> value="">px</option>
<option <?php selected( get_post_meta( get_the_ID(), '_generate_hero_padding_right_unit_mobile', true ), '%' ); ?> value="%">%</option>
</select>
</div>
<span><?php esc_html_e( 'Right', 'gp-premium' ); ?></span>
</div>
<div class="padding-element">
<div class="padding-element-options">
<input type="number" id="_generate_hero_padding_bottom_mobile" name="_generate_hero_padding_bottom_mobile" value="<?php echo esc_attr( get_post_meta( get_the_ID(), '_generate_hero_padding_bottom_mobile', true ) ); ?>" />
<select id="_generate_hero_padding_bottom_unit_mobile" name="_generate_hero_padding_bottom_unit_mobile">
<option <?php selected( get_post_meta( get_the_ID(), '_generate_hero_padding_bottom_unit_mobile', true ), '' ); ?> value="">px</option>
<option <?php selected( get_post_meta( get_the_ID(), '_generate_hero_padding_bottom_unit_mobile', true ), '%' ); ?> value="%">%</option>
</select>
</div>
<span><?php esc_html_e( 'Bottom', 'gp-premium' ); ?></span>
</div>
<div class="padding-element">
<div class="padding-element-options">
<input type="number" id="_generate_hero_padding_left_mobile" name="_generate_hero_padding_left_mobile" value="<?php echo esc_attr( get_post_meta( get_the_ID(), '_generate_hero_padding_left_mobile', true ) ); ?>" />
<select id="_generate_hero_padding_left_unit_mobile" name="_generate_hero_padding_left_unit_mobile">
<option <?php selected( get_post_meta( get_the_ID(), '_generate_hero_padding_left_unit_mobile', true ), '' ); ?> value="">px</option>
<option <?php selected( get_post_meta( get_the_ID(), '_generate_hero_padding_left_unit_mobile', true ), '%' ); ?> value="%">%</option>
</select>
</div>
<span><?php esc_html_e( 'Left', 'gp-premium' ); ?></span>
</div>
</div>
</td>
</tr>
<tr class="generate-element-row">
<td class="generate-element-row-heading">
<label for="_generate_hero_background_image"><?php _e( 'Background Image', 'gp-premium' ); ?></label>
</td>
<td class="generate-element-row-content">
<select id="_generate_hero_background_image" name="_generate_hero_background_image">
<option <?php selected( get_post_meta( get_the_ID(), '_generate_hero_background_image', true ), '' ); ?> value=""><?php esc_attr_e( 'No Background Image', 'gp-premium' ); ?></option>
<option <?php selected( get_post_meta( get_the_ID(), '_generate_hero_background_image', true ), 'featured-image' ); ?> value="featured-image"><?php esc_attr_e( 'Featured Image', 'gp-premium' ); ?></option>
<option <?php selected( get_post_meta( get_the_ID(), '_generate_hero_background_image', true ), 'custom-image' ); ?> value="custom-image"><?php esc_attr_e( 'Custom Image', 'gp-premium' ); ?></option>
</select>
</td>
</tr>
<?php
$background_image = get_post_meta( get_the_ID(), '_generate_hero_background_image', true );
if ( 'custom-image' === $background_image ) {
$image_text = __( 'Custom Image', 'gp-premium' );
} else {
$image_text = __( 'Fallback Image', 'gp-premium' );
}
?>
<tr class="generate-element-row requires-background-image" <?php echo '' === $background_image ? 'style="display: none;"' : ''; ?>>
<td class="generate-element-row-heading">
<label for="_generate_hero_background_link_color_hover"><span class="image-text"><?php echo esc_html( $image_text ); ?></span></label>
</td>
<td class="generate-element-row-content">
<div class="change-featured-image" <?php echo ! has_post_thumbnail() ? 'style="display: none;"' : ''; ?>>
<div class="image-preview">
<?php the_post_thumbnail( 'thumbnail', array( 9999, 50 ) ); ?>
</div>
<?php
printf(
'<a class="button" href="#">%s</a>',
esc_html__( 'Change', 'gp-premium' )
);
printf(
' <a class="button remove-image" href="#">%s</a>',
esc_html__( 'Remove', 'gp-premium' )
);
?>
</div>
<div class="set-featured-image" <?php echo has_post_thumbnail() ? 'style="display: none;"' : ''; ?>>
<?php
printf(
'<a class="button" href="#">%s</a>',
sprintf(
/* translators: Upload Custom Image or Fallback image */
esc_html__( 'Upload %s', 'gp-premium' ),
'<span class="image-text">' . esc_html( $image_text ) . '</span>'
)
);
?>
</div>
</td>
</tr>
<tr class="generate-element-row requires-background-image" <?php echo ! $background_image ? 'style="display: none;"' : ''; ?>>
<td class="generate-element-row-heading">
<label for="_generate_hero_background_position"><?php _e( 'Background Position', 'gp-premium' ); ?></label>
</td>
<td class="generate-element-row-content">
<select id="_generate_hero_background_position" name="_generate_hero_background_position">
<option <?php selected( get_post_meta( get_the_ID(), '_generate_hero_background_position', true ), '' ); ?> value="">left top</option>
<option <?php selected( get_post_meta( get_the_ID(), '_generate_hero_background_position', true ), 'left center' ); ?> value="left center" <?php echo get_post_meta( get_the_ID(), '_generate_hero_background_parallax', true ) ? 'disabled' : ''; ?>>left center</option>
<option <?php selected( get_post_meta( get_the_ID(), '_generate_hero_background_position', true ), 'left bottom' ); ?> value="left bottom" <?php echo get_post_meta( get_the_ID(), '_generate_hero_background_parallax', true ) ? 'disabled' : ''; ?>>left bottom</option>
<option <?php selected( get_post_meta( get_the_ID(), '_generate_hero_background_position', true ), 'right top' ); ?> value="right top">right top</option>
<option <?php selected( get_post_meta( get_the_ID(), '_generate_hero_background_position', true ), 'right center' ); ?> value="right center" <?php echo get_post_meta( get_the_ID(), '_generate_hero_background_parallax', true ) ? 'disabled' : ''; ?>>right center</option>
<option <?php selected( get_post_meta( get_the_ID(), '_generate_hero_background_position', true ), 'right bottom' ); ?> value="right bottom" <?php echo get_post_meta( get_the_ID(), '_generate_hero_background_parallax', true ) ? 'disabled' : ''; ?>>right bottom</option>
<option <?php selected( get_post_meta( get_the_ID(), '_generate_hero_background_position', true ), 'center top' ); ?> value="center top">center top</option>
<option <?php selected( get_post_meta( get_the_ID(), '_generate_hero_background_position', true ), 'center center' ); ?> value="center center" <?php echo get_post_meta( get_the_ID(), '_generate_hero_background_parallax', true ) ? 'disabled' : ''; ?>>center center</option>
<option <?php selected( get_post_meta( get_the_ID(), '_generate_hero_background_position', true ), 'center bottom' ); ?> value="center bottom" <?php echo get_post_meta( get_the_ID(), '_generate_hero_background_parallax', true ) ? 'disabled' : ''; ?>>center bottom</option>
</select>
</td>
</tr>
<tr class="generate-element-row requires-background-image" <?php echo ! $background_image ? 'style="display: none;"' : ''; ?>>
<td class="generate-element-row-heading">
<label for="_generate_hero_background_parallax"><?php _e( 'Parallax', 'gp-premium' ); ?></label>
</td>
<td class="generate-element-row-content">
<input type="checkbox" name="_generate_hero_background_parallax" id="_generate_hero_background_parallax" value="true" <?php checked( get_post_meta( get_the_ID(), '_generate_hero_background_parallax', true ), 'true' ); ?> />
</td>
</tr>
<tr class="generate-element-row requires-background-image" <?php echo ! $background_image ? 'style="display: none;"' : ''; ?>>
<td class="generate-element-row-heading">
<label for="_generate_hero_disable_featured_image"><?php _e( 'Disable Featured Image', 'gp-premium' ); ?></label>
<span class="tip" data-balloon="<?php esc_attr_e( 'Disable the featured image on posts with this hero area.', 'gp-premium' ); ?>" data-balloon-pos="down">?</span>
</td>
<td class="generate-element-row-content">
<input type="checkbox" name="_generate_hero_disable_featured_image" id="_generate_hero_disable_featured_image" value="true" <?php checked( get_post_meta( get_the_ID(), '_generate_hero_disable_featured_image', true ), 'true' ); ?> />
</td>
</tr>
<tr class="generate-element-row requires-background-image" <?php echo ! $background_image ? 'style="display: none;"' : ''; ?>>
<td class="generate-element-row-heading">
<label for="_generate_hero_background_overlay"><?php _e( 'Background Overlay', 'gp-premium' ); ?></label>
<span class="tip" data-balloon="<?php esc_attr_e( 'Use the background color as a background overlay.', 'gp-premium' ); ?>" data-balloon-pos="down">?</span>
</td>
<td class="generate-element-row-content">
<input type="checkbox" name="_generate_hero_background_overlay" id="_generate_hero_background_overlay" value="true" <?php checked( get_post_meta( get_the_ID(), '_generate_hero_background_overlay', true ), 'true' ); ?> />
</td>
</tr>
<tr class="generate-element-row">
<td class="generate-element-row-heading">
<label for="_generate_hero_background_color"><?php _e( 'Background Color', 'gp-premium' ); ?></label>
</td>
<td class="generate-element-row-content">
<input class="color-picker" data-alpha-enabled="true" data-alpha-color-type="hex" type="text" name="_generate_hero_background_color" id="_generate_hero_background_color" value="<?php echo esc_attr( get_post_meta( get_the_ID(), '_generate_hero_background_color', true ) ); ?>" />
</td>
</tr>
<tr class="generate-element-row">
<td class="generate-element-row-heading">
<label for="_generate_hero_text_color"><?php _e( 'Text Color', 'gp-premium' ); ?></label>
</td>
<td class="generate-element-row-content">
<input class="color-picker" type="text" name="_generate_hero_text_color" id="_generate_hero_text_color" value="<?php echo esc_attr( get_post_meta( get_the_ID(), '_generate_hero_text_color', true ) ); ?>" />
</td>
</tr>
<tr class="generate-element-row">
<td class="generate-element-row-heading">
<label for="_generate_hero_link_color"><?php _e( 'Link Color', 'gp-premium' ); ?></label>
</td>
<td class="generate-element-row-content">
<input class="color-picker" type="text" name="_generate_hero_link_color" id="_generate_hero_link_color" value="<?php echo esc_attr( get_post_meta( get_the_ID(), '_generate_hero_link_color', true ) ); ?>" />
</td>
</tr>
<tr class="generate-element-row">
<td class="generate-element-row-heading">
<label for="_generate_hero_background_link_color_hover"><?php _e( 'Link Color Hover', 'gp-premium' ); ?></label>
</td>
<td class="generate-element-row-content">
<input class="color-picker" type="text" name="_generate_hero_background_link_color_hover" id="_generate_hero_background_link_color_hover" value="<?php echo esc_attr( get_post_meta( get_the_ID(), '_generate_hero_background_link_color_hover', true ) ); ?>" />
</td>
</tr>
</tbody>
</table>
<table class="generate-elements-settings" data-type="header" data-tab="site-header">
<tbody>
<tr class="generate-element-row">
<td class="generate-element-row-heading">
<label for="_generate_site_header_merge"><?php _e( 'Merge with Content', 'gp-premium' ); ?></label>
<span class="tip" data-balloon="<?php esc_attr_e( 'Place your site header on top of the element below it.', 'gp-premium' ); ?>" data-balloon-pos="down">?</span>
</td>
<td class="generate-element-row-content">
<select id="_generate_site_header_merge" name="_generate_site_header_merge">
<option <?php selected( get_post_meta( get_the_ID(), '_generate_site_header_merge', true ), '' ); ?> value=""><?php esc_attr_e( 'No Merge', 'gp-premium' ); ?></option>
<option <?php selected( get_post_meta( get_the_ID(), '_generate_site_header_merge', true ), 'merge' ); ?> value="merge"><?php esc_attr_e( 'Merge', 'gp-premium' ); ?></option>
<option <?php selected( get_post_meta( get_the_ID(), '_generate_site_header_merge', true ), 'merge-desktop' ); ?> value="merge-desktop"><?php esc_attr_e( 'Merge on Desktop Only', 'gp-premium' ); ?></option>
</select>
</td>
</tr>
<tr class="generate-element-row requires-header-merge" <?php echo ! $merge ? 'style="display: none;"' : ''; ?>>
<td class="generate-element-row-heading">
<label for="_generate_site_header_height"><?php _e( 'Offset Site Header Height', 'gp-premium' ); ?></label>
<span class="tip" data-balloon="<?php esc_attr_e( 'Add to the top padding of your Page Hero to prevent overlapping.', 'gp-premium' ); ?>" data-balloon-pos="down">?</span>
</td>
<td class="generate-element-row-content">
<div class="responsive-controls single-responsive-value">
<a href="#" class="is-selected" data-control="desktop"><span class="dashicons dashicons-desktop"></span></a>
<a href="#" data-control="mobile"><span class="dashicons dashicons-smartphone"></span></a>
</div>
<div class="padding-container single-value-padding-container desktop">
<div class="padding-element">
<input type="number" id="_generate_site_header_height" name="_generate_site_header_height" value="<?php echo esc_attr( get_post_meta( get_the_ID(), '_generate_site_header_height', true ) ); ?>" />
<span class="unit">px</span>
</div>
</div>
<div class="padding-container single-value-padding-container mobile" style="display: none;">
<div class="padding-element">
<input type="number" id="_generate_site_header_height_mobile" name="_generate_site_header_height_mobile" value="<?php echo esc_attr( get_post_meta( get_the_ID(), '_generate_site_header_height_mobile', true ) ); ?>" />
<span class="unit">px</span>
</div>
</div>
</td>
</tr>
<tr class="generate-element-row requires-header-merge" <?php echo ! $merge ? 'style="display: none;"' : ''; ?>>
<td class="generate-element-row-heading">
<label for="_generate_site_header_background_color"><?php _e( 'Header Background', 'gp-premium' ); ?></label>
</td>
<td class="generate-element-row-content">
<input class="color-picker" data-alpha-enabled="true" data-alpha-color-type="hex" type="text" name="_generate_site_header_background_color" id="_generate_site_header_background_color" value="<?php echo esc_attr( get_post_meta( get_the_ID(), '_generate_site_header_background_color', true ) ); ?>" />
</td>
</tr>
<?php if ( GeneratePress_Elements_Helper::does_option_exist( 'site-title' ) ) : ?>
<tr class="generate-element-row requires-header-merge" <?php echo ! $merge ? 'style="display: none;"' : ''; ?>>
<td class="generate-element-row-heading">
<label for="_generate_site_header_title_color"><?php _e( 'Site Title', 'gp-premium' ); ?></label>
</td>
<td class="generate-element-row-content">
<input class="color-picker" type="text" name="_generate_site_header_title_color" id="_generate_site_header_title_color" value="<?php echo esc_attr( get_post_meta( get_the_ID(), '_generate_site_header_title_color', true ) ); ?>" />
</td>
</tr>
<?php endif; ?>
<?php if ( GeneratePress_Elements_Helper::does_option_exist( 'site-tagline' ) ) : ?>
<tr class="generate-element-row requires-header-merge" <?php echo ! $merge ? 'style="display: none;"' : ''; ?>>
<td class="generate-element-row-heading">
<label for="_generate_site_header_tagline_color"><?php _e( 'Site Tagline', 'gp-premium' ); ?></label>
</td>
<td class="generate-element-row-content">
<input class="color-picker" type="text" name="_generate_site_header_tagline_color" id="_generate_site_header_tagline_color" value="<?php echo esc_attr( get_post_meta( get_the_ID(), '_generate_site_header_tagline_color', true ) ); ?>" />
</td>
</tr>
<?php endif; ?>
<?php if ( GeneratePress_Elements_Helper::does_option_exist( 'site-logo' ) ) : ?>
<tr class="generate-element-row">
<td class="generate-element-row-heading">
<label for="_generate_site_header_merge"><?php _e( 'Site Logo', 'gp-premium' ); ?></label>
</td>
<td class="generate-element-row-content">
<div class="media-container">
<div class="gp-media-preview">
<?php
$site_logo_id = get_post_meta( get_the_ID(), '_generate_site_logo', true );
$site_logo_url = wp_get_attachment_url( absint( $site_logo_id ) );
if ( $site_logo_url ) {
echo '<img src="' . esc_url( $site_logo_url ) . '" alt="" height="30" />';
}
?>
</div>
<input type="button" data-title="<?php esc_attr_e( 'Site Logo', 'gp-premium' ); ?>" data-preview="true" class="button generate-upload-file" value="<?php esc_attr_e( 'Upload', 'gp-premium' ); ?>" />
<input type="button" class="button remove-field" value="<?php esc_attr_e( 'Remove', 'gp-premium' ); ?>" <?php echo ! $site_logo_id ? 'style="display: none;"' : ''; ?> />
<input type="hidden" class="media-field" name="_generate_site_logo" value="<?php echo esc_attr( $site_logo_id ); ?>" />
</div>
</td>
</tr>
<?php endif; ?>
<?php if ( GeneratePress_Elements_Helper::does_option_exist( 'retina-logo' ) ) : ?>
<tr class="generate-element-row">
<td class="generate-element-row-heading">
<label for="_generate_retina_logo"><?php _e( 'Retina Logo', 'gp-premium' ); ?></label>
</td>
<td class="generate-element-row-content">
<div class="media-container">
<div class="gp-media-preview">
<?php
$retina_site_logo_id = get_post_meta( get_the_ID(), '_generate_retina_logo', true );
$retina_site_logo_url = wp_get_attachment_url( absint( $retina_site_logo_id ) );
if ( $retina_site_logo_url ) {
echo '<img src="' . esc_url( $retina_site_logo_url ) . '" alt="" height="30" />';
}
?>
</div>
<input type="button" data-title="<?php esc_attr_e( 'Retina Logo', 'gp-premium' ); ?>" data-preview="true" class="button generate-upload-file" value="<?php esc_attr_e( 'Upload', 'gp-premium' ); ?>" />
<input type="button" class="button remove-field" value="<?php esc_attr_e( 'Remove', 'gp-premium' ); ?>" <?php echo ! $retina_site_logo_id ? 'style="display: none;"' : ''; ?> />
<input type="hidden" class="media-field" name="_generate_retina_logo" value="<?php echo esc_attr( $retina_site_logo_id ); ?>" />
</div>
</td>
</tr>
<?php endif; ?>
<?php if ( GeneratePress_Elements_Helper::does_option_exist( 'navigation-logo' ) ) : ?>
<tr class="generate-element-row">
<td class="generate-element-row-heading">
<label for="_generate_navigation_logo"><?php _e( 'Navigation Logo', 'gp-premium' ); ?></label>
</td>
<td class="generate-element-row-content">
<div class="media-container">
<div class="gp-media-preview">
<?php
$navigation_logo_id = get_post_meta( get_the_ID(), '_generate_navigation_logo', true );
$navigation_logo_url = wp_get_attachment_url( absint( $navigation_logo_id ) );
if ( $navigation_logo_url ) {
echo '<img src="' . esc_url( $navigation_logo_url ) . '" alt="" height="30" />';
}
?>
</div>
<input type="button" data-title="<?php esc_attr_e( 'Retina Logo', 'gp-premium' ); ?>" data-preview="true" class="button generate-upload-file" value="<?php esc_attr_e( 'Upload', 'gp-premium' ); ?>" />
<input type="button" class="button remove-field" value="<?php esc_attr_e( 'Remove', 'gp-premium' ); ?>" <?php echo ! $navigation_logo_id ? 'style="display: none;"' : ''; ?> />
<input type="hidden" class="media-field" name="_generate_navigation_logo" value="<?php echo esc_attr( $navigation_logo_id ); ?>" />
</div>
</td>
</tr>
<?php endif; ?>
<?php if ( GeneratePress_Elements_Helper::does_option_exist( 'mobile-logo' ) ) : ?>
<tr class="generate-element-row">
<td class="generate-element-row-heading">
<label for="_generate_mobile_logo"><?php _e( 'Mobile Header Logo', 'gp-premium' ); ?></label>
</td>
<td class="generate-element-row-content">
<div class="media-container">
<div class="gp-media-preview">
<?php
$mobile_logo_id = get_post_meta( get_the_ID(), '_generate_mobile_logo', true );
$mobile_logo_url = wp_get_attachment_url( absint( $mobile_logo_id ) );
if ( $mobile_logo_url ) {
echo '<img src="' . esc_url( $mobile_logo_url ) . '" alt="" height="30" />';
}
?>
</div>
<input type="button" data-title="<?php esc_attr_e( 'Retina Logo', 'gp-premium' ); ?>" data-preview="true" class="button generate-upload-file" value="<?php esc_attr_e( 'Upload', 'gp-premium' ); ?>" />
<input type="button" class="button remove-field" value="<?php esc_attr_e( 'Remove', 'gp-premium' ); ?>" <?php echo ! $mobile_logo_id ? 'style="display: none;"' : ''; ?> />
<input type="hidden" class="media-field" name="_generate_mobile_logo" value="<?php echo esc_attr( $mobile_logo_id ); ?>" />
</div>
</td>
</tr>
<?php endif; ?>
<tr class="generate-element-row">
<td class="generate-element-row-heading">
<label for="_generate_navigation_location"><?php _e( 'Navigation Location', 'gp-premium' ); ?></label>
</td>
<td class="generate-element-row-content">
<select id="_generate_navigation_location" name="_generate_navigation_location">
<option <?php selected( get_post_meta( get_the_ID(), '_generate_navigation_location', true ), '' ); ?> value=""><?php esc_attr_e( 'Default', 'gp-premium' ); ?></option>
<option <?php selected( get_post_meta( get_the_ID(), '_generate_navigation_location', true ), 'nav-below-header' ); ?> value="nav-below-header"><?php esc_attr_e( 'Below Header', 'gp-premium' ); ?></option>
<option <?php selected( get_post_meta( get_the_ID(), '_generate_navigation_location', true ), 'nav-above-header' ); ?> value="nav-above-header"><?php esc_attr_e( 'Above Header', 'gp-premium' ); ?></option>
<option <?php selected( get_post_meta( get_the_ID(), '_generate_navigation_location', true ), 'nav-float-right' ); ?> value="nav-float-right"><?php esc_attr_e( 'Float Right', 'gp-premium' ); ?></option>
<option <?php selected( get_post_meta( get_the_ID(), '_generate_navigation_location', true ), 'nav-float-left' ); ?> value="nav-float-left"><?php esc_attr_e( 'Float Left', 'gp-premium' ); ?></option>
<option <?php selected( get_post_meta( get_the_ID(), '_generate_navigation_location', true ), 'nav-left-sidebar' ); ?> value="nav-left-sidebar"><?php esc_attr_e( 'Left Sidebar', 'gp-premium' ); ?></option>
<option <?php selected( get_post_meta( get_the_ID(), '_generate_navigation_location', true ), 'nav-right-sidebar' ); ?> value="nav-right-sidebar"><?php esc_attr_e( 'Right Sidebar', 'gp-premium' ); ?></option>
<option <?php selected( get_post_meta( get_the_ID(), '_generate_navigation_location', true ), 'no-navigation' ); ?> value="no-navigation"><?php esc_attr_e( 'No Navigation', 'gp-premium' ); ?></option>
</select>
</td>
</tr>
<tr class="generate-element-row requires-header-merge" <?php echo ! $merge ? 'style="display: none;"' : ''; ?>>
<td class="generate-element-row-heading">
<label for="_generate_navigation_colors"><?php _e( 'Navigation Colors', 'gp-premium' ); ?></label>
</td>
<td class="generate-element-row-content">
<input type="checkbox" name="_generate_navigation_colors" id="_generate_navigation_colors" value="true" <?php checked( get_post_meta( get_the_ID(), '_generate_navigation_colors', true ), 'true' ); ?> />
</td>
</tr>
<tr class="generate-element-row requires-navigation-colors" <?php echo ! $merge || ! get_post_meta( get_the_ID(), '_generate_navigation_colors', true ) ? 'style="display: none;"' : ''; ?>>
<td class="generate-element-row-heading">
<label for="_generate_navigation_background_color"><?php _e( 'Navigation Background', 'gp-premium' ); ?></label>
</td>
<td class="generate-element-row-content">
<input class="color-picker" data-alpha-enabled="true" data-alpha-color-type="hex" type="text" name="_generate_navigation_background_color" id="_generate_navigation_background_color" value="<?php echo esc_attr( get_post_meta( get_the_ID(), '_generate_navigation_background_color', true ) ); ?>" />
</td>
</tr>
<tr class="generate-element-row requires-navigation-colors" <?php echo ! $merge || ! get_post_meta( get_the_ID(), '_generate_navigation_colors', true ) ? 'style="display: none;"' : ''; ?>>
<td class="generate-element-row-heading">
<label for="_generate_navigation_text_color"><?php _e( 'Navigation Text', 'gp-premium' ); ?></label>
</td>
<td class="generate-element-row-content">
<input class="color-picker" type="text" name="_generate_navigation_text_color" id="_generate_navigation_text_color" value="<?php echo esc_attr( get_post_meta( get_the_ID(), '_generate_navigation_text_color', true ) ); ?>" />
</td>
</tr>
<tr class="generate-element-row requires-navigation-colors" <?php echo ! $merge || ! get_post_meta( get_the_ID(), '_generate_navigation_colors', true ) ? 'style="display: none;"' : ''; ?>>
<td class="generate-element-row-heading">
<label for="_generate_navigation_background_color_hover"><?php _e( 'Navigation Background Hover', 'gp-premium' ); ?></label>
</td>
<td class="generate-element-row-content">
<input class="color-picker" data-alpha-enabled="true" data-alpha-color-type="hex" type="text" name="_generate_navigation_background_color_hover" id="_generate_navigation_background_color_hover" value="<?php echo esc_attr( get_post_meta( get_the_ID(), '_generate_navigation_background_color_hover', true ) ); ?>" />
</td>
</tr>
<tr class="generate-element-row requires-navigation-colors" <?php echo ! $merge || ! get_post_meta( get_the_ID(), '_generate_navigation_colors', true ) ? 'style="display: none;"' : ''; ?>>
<td class="generate-element-row-heading">
<label for="_generate_navigation_text_color_hover"><?php _e( 'Navigation Text Hover', 'gp-premium' ); ?></label>
</td>
<td class="generate-element-row-content">
<input class="color-picker" type="text" name="_generate_navigation_text_color_hover" id="_generate_navigation_text_color_hover" value="<?php echo esc_attr( get_post_meta( get_the_ID(), '_generate_navigation_text_color_hover', true ) ); ?>" />
</td>
</tr>
<tr class="generate-element-row requires-navigation-colors" <?php echo ! $merge || ! get_post_meta( get_the_ID(), '_generate_navigation_colors', true ) ? 'style="display: none;"' : ''; ?>>
<td class="generate-element-row-heading">
<label for="_generate_navigation_background_color_current"><?php _e( 'Navigation Background Current', 'gp-premium' ); ?></label>
</td>
<td class="generate-element-row-content">
<input class="color-picker" data-alpha-enabled="true" data-alpha-color-type="hex" type="text" name="_generate_navigation_background_color_current" id="_generate_navigation_background_color_current" value="<?php echo esc_attr( get_post_meta( get_the_ID(), '_generate_navigation_background_color_current', true ) ); ?>" />
</td>
</tr>
<tr class="generate-element-row requires-navigation-colors" <?php echo ! $merge || ! get_post_meta( get_the_ID(), '_generate_navigation_colors', true ) ? 'style="display: none;"' : ''; ?>>
<td class="generate-element-row-heading">
<label for="_generate_navigation_text_color_current"><?php _e( 'Navigation Text Current', 'gp-premium' ); ?></label>
</td>
<td class="generate-element-row-content">
<input class="color-picker" type="text" name="_generate_navigation_text_color_current" id="_generate_navigation_text_color_current" value="<?php echo esc_attr( get_post_meta( get_the_ID(), '_generate_navigation_text_color_current', true ) ); ?>" />
</td>
</tr>
</tbody>
</table>
<?php endif; ?>
<?php if ( 'layout' === $type ) : ?>
<table class="generate-elements-settings" data-type="layout" data-tab="sidebars">
<tbody>
<tr class="generate-element-row">
<td class="generate-element-row-heading">
<label for="_generate_sidebar_layout"><?php _e( 'Sidebar Layout', 'gp-premium' ); ?></label>
</td>
<td class="generate-element-row-content">
<div class="layout-radio-item">
<label for="default-sidebar-layout">
<input type="radio" name="_generate_sidebar_layout" id="default-sidebar-layout" <?php checked( get_post_meta( get_the_ID(), '_generate_sidebar_layout', true ), '' ); ?> value="">
<?php esc_html_e( 'Default', 'gp-premium' ); ?>
</label>
</div>
<div class="layout-radio-item">
<label for="right-sidebar-layout" title="<?php esc_attr_e( 'Right Sidebar', 'gp-premium' ); ?>">
<input type="radio" name="_generate_sidebar_layout" id="right-sidebar-layout" <?php checked( get_post_meta( get_the_ID(), '_generate_sidebar_layout', true ), 'right-sidebar' ); ?> value="right-sidebar">
<?php esc_html_e( 'Content', 'gp-premium' ); ?> / <strong><?php echo esc_html_x( 'Sidebar', 'Short name for meta box', 'gp-premium' ); ?></strong>
</label>
</div>
<div class="layout-radio-item">
<label for="left-sidebar-layout" title="<?php esc_attr_e( 'Left Sidebar', 'gp-premium' ); ?>">
<input type="radio" name="_generate_sidebar_layout" id="left-sidebar-layout" <?php checked( get_post_meta( get_the_ID(), '_generate_sidebar_layout', true ), 'left-sidebar' ); ?> value="left-sidebar">
<strong><?php echo esc_html_x( 'Sidebar', 'Short name for meta box', 'gp-premium' ); ?></strong> / <?php esc_html_e( 'Content', 'gp-premium' ); ?>
</label>
</div>
<div class="layout-radio-item">
<label for="no-sidebar-layout" title="<?php esc_attr_e( 'No Sidebars', 'gp-premium' ); ?>">
<input type="radio" name="_generate_sidebar_layout" id="no-sidebar-layout" <?php checked( get_post_meta( get_the_ID(), '_generate_sidebar_layout', true ), 'no-sidebar' ); ?> value="no-sidebar">
<?php esc_html_e( 'Content (no sidebars)', 'gp-premium' ); ?>
</label>
</div>
<div class="layout-radio-item">
<label for="both-sidebars-layout" title="<?php esc_attr_e( 'Both Sidebars', 'gp-premium' ); ?>">
<input type="radio" name="_generate_sidebar_layout" id="both-sidebars-layout" <?php checked( get_post_meta( get_the_ID(), '_generate_sidebar_layout', true ), 'both-sidebars' ); ?> value="both-sidebars">
<strong><?php echo esc_html_x( 'Sidebar', 'Short name for meta box', 'gp-premium' ); ?></strong> / <?php esc_html_e( 'Content', 'gp-premium' ); ?> / <strong><?php echo esc_html_x( 'Sidebar', 'Short name for meta box', 'gp-premium' ); ?></strong>
</label>
</div>
<div class="layout-radio-item">
<label for="both-sidebars-left-layout" title="<?php esc_attr_e( 'Both Sidebars on Left', 'gp-premium' ); ?>">
<input type="radio" name="_generate_sidebar_layout" id="both-sidebars-left-layout" <?php checked( get_post_meta( get_the_ID(), '_generate_sidebar_layout', true ), 'both-left' ); ?> value="both-left">
<strong><?php echo esc_html_x( 'Sidebar', 'Short name for meta box', 'gp-premium' ); ?></strong> / <strong><?php echo esc_html_x( 'Sidebar', 'Short name for meta box', 'gp-premium' ); ?></strong> / <?php esc_html_e( 'Content', 'gp-premium' ); ?>
</label>
</div>
<div class="layout-radio-item">
<label for="both-sidebars-right-layout" title="<?php esc_attr_e( 'Both Sidebars on Right', 'gp-premium' ); ?>">
<input type="radio" name="_generate_sidebar_layout" id="both-sidebars-right-layout" <?php checked( get_post_meta( get_the_ID(), '_generate_sidebar_layout', true ), 'both-right' ); ?> value="both-right">
<?php esc_html_e( 'Content', 'gp-premium' ); ?> / <strong><?php echo esc_html_x( 'Sidebar', 'Short name for meta box', 'gp-premium' ); ?></strong> / <strong><?php echo esc_html_x( 'Sidebar', 'Short name for meta box', 'gp-premium' ); ?></strong>
</label>
</div>
</td>
</tr>
</tbody>
</table>
<table class="generate-elements-settings" data-type="layout" data-tab="footer-widgets">
<tbody>
<tr class="generate-element-row">
<td class="generate-element-row-heading">
<label for="_generate_footer_widgets"><?php _e( 'Footer Widgets', 'gp-premium' ); ?></label>
</td>
<td class="generate-element-row-content">
<div class="layout-radio-item">
<label for="default-footer-widgets">
<input type="radio" name="_generate_footer_widgets" id="default-footer-widgets" <?php checked( get_post_meta( get_the_ID(), '_generate_footer_widgets', true ), '' ); ?> value="">
<?php esc_html_e( 'Default', 'gp-premium' ); ?>
</label>
</div>
<div class="layout-radio-item">
<label for="footer-widget-0">
<input type="radio" name="_generate_footer_widgets" id="footer-widget-0" <?php checked( get_post_meta( get_the_ID(), '_generate_footer_widgets', true ), 'no-widgets' ); ?> value="no-widgets">
<?php esc_attr_e( '0 Widgets', 'gp-premium' ); ?>
</label>
</div>
<div class="layout-radio-item">
<label for="footer-widget-1">
<input type="radio" name="_generate_footer_widgets" id="footer-widget-1" <?php checked( get_post_meta( get_the_ID(), '_generate_footer_widgets', true ), '1' ); ?> value="1">
<?php esc_attr_e( '1 Widget', 'gp-premium' ); ?>
</label>
</div>
<div class="layout-radio-item">
<label for="footer-widget-2">
<input type="radio" name="_generate_footer_widgets" id="footer-widget-2" <?php checked( get_post_meta( get_the_ID(), '_generate_footer_widgets', true ), '2' ); ?> value="2">
<?php esc_attr_e( '2 Widgets', 'gp-premium' ); ?>
</label>
</div>
<div class="layout-radio-item">
<label for="footer-widget-3">
<input type="radio" name="_generate_footer_widgets" id="footer-widget-3" <?php checked( get_post_meta( get_the_ID(), '_generate_footer_widgets', true ), '3' ); ?> value="3">
<?php esc_attr_e( '3 Widgets', 'gp-premium' ); ?>
</label>
</div>
<div class="layout-radio-item">
<label for="footer-widget-4">
<input type="radio" name="_generate_footer_widgets" id="footer-widget-4" <?php checked( get_post_meta( get_the_ID(), '_generate_footer_widgets', true ), '4' ); ?> value="4">
<?php esc_attr_e( '4 Widgets', 'gp-premium' ); ?>
</label>
</div>
<div class="layout-radio-item">
<label for="footer-widget-5">
<input type="radio" name="_generate_footer_widgets" id="footer-widget-5" <?php checked( get_post_meta( get_the_ID(), '_generate_footer_widgets', true ), '5' ); ?> value="5">
<?php esc_attr_e( '5 Widgets', 'gp-premium' ); ?>
</label>
</div>
</td>
</tr>
</tbody>
</table>
<table class="generate-elements-settings" data-tab="disable-elements" data-type="layout">
<tbody>
<tr class="generate-element-row">
<td class="generate-element-row-heading">
<label for="_generate_disable_site_header"><?php _e( 'Site Header', 'gp-premium' ); ?></label>
</td>
<td class="generate-element-row-content">
<input type="checkbox" name="_generate_disable_site_header" id="_generate_disable_site_header" value="true" <?php checked( get_post_meta( get_the_ID(), '_generate_disable_site_header', true ), 'true' ); ?> />
</td>
</tr>
<tr class="generate-element-row">
<td class="generate-element-row-heading">
<label for="_generate_disable_mobile_header"><?php _e( 'Mobile Header', 'gp-premium' ); ?></label>
</td>
<td class="generate-element-row-content">
<input type="checkbox" name="_generate_disable_mobile_header" id="_generate_disable_mobile_header" value="true" <?php checked( get_post_meta( get_the_ID(), '_generate_disable_mobile_header', true ), 'true' ); ?> />
</td>
</tr>
<tr class="generate-element-row">
<td class="generate-element-row-heading">
<label for="_generate_disable_top_bar"><?php _e( 'Top Bar', 'gp-premium' ); ?></label>
</td>
<td class="generate-element-row-content">
<input type="checkbox" name="_generate_disable_top_bar" id="_generate_disable_top_bar" value="true" <?php checked( get_post_meta( get_the_ID(), '_generate_disable_top_bar', true ), 'true' ); ?> />
</td>
</tr>
<tr class="generate-element-row">
<td class="generate-element-row-heading">
<label for="_generate_disable_primary_navigation"><?php _e( 'Primary Navigation', 'gp-premium' ); ?></label>
</td>
<td class="generate-element-row-content">
<input type="checkbox" name="_generate_disable_primary_navigation" id="_generate_disable_primary_navigation" value="true" <?php checked( get_post_meta( get_the_ID(), '_generate_disable_primary_navigation', true ), 'true' ); ?> />
</td>
</tr>
<tr class="generate-element-row">
<td class="generate-element-row-heading">
<label for="_generate_disable_secondary_navigation"><?php _e( 'Secondary Navigation', 'gp-premium' ); ?></label>
</td>
<td class="generate-element-row-content">
<input type="checkbox" name="_generate_disable_secondary_navigation" id="_generate_disable_secondary_navigation" value="true" <?php checked( get_post_meta( get_the_ID(), '_generate_disable_secondary_navigation', true ), 'true' ); ?> />
</td>
</tr>
<tr class="generate-element-row">
<td class="generate-element-row-heading">
<label for="_generate_disable_featured_image"><?php _e( 'Featured Image', 'gp-premium' ); ?></label>
</td>
<td class="generate-element-row-content">
<input type="checkbox" name="_generate_disable_featured_image" id="_generate_disable_featured_image" value="true" <?php checked( get_post_meta( get_the_ID(), '_generate_disable_featured_image', true ), 'true' ); ?> />
</td>
</tr>
<tr class="generate-element-row">
<td class="generate-element-row-heading">
<label for="_generate_disable_content_title"><?php _e( 'Content Title', 'gp-premium' ); ?></label>
</td>
<td class="generate-element-row-content">
<input type="checkbox" name="_generate_disable_content_title" id="_generate_disable_content_title" value="true" <?php checked( get_post_meta( get_the_ID(), '_generate_disable_content_title', true ), 'true' ); ?> />
</td>
</tr>
<tr class="generate-element-row">
<td class="generate-element-row-heading">
<label for="_generate_disable_footer"><?php _e( 'Footer', 'gp-premium' ); ?></label>
</td>
<td class="generate-element-row-content">
<input type="checkbox" name="_generate_disable_footer" id="_generate_disable_footer" value="true" <?php checked( get_post_meta( get_the_ID(), '_generate_disable_footer', true ), 'true' ); ?> />
</td>
</tr>
</tbody>
</table>
<table class="generate-elements-settings" data-type="layout" data-tab="content">
<tbody>
<tr class="generate-element-row">
<td class="generate-element-row-heading">
<label for="_generate_content_area"><?php _e( 'Content Area', 'gp-premium' ); ?></label>
</td>
<td class="generate-element-row-content">
<div class="layout-radio-item">
<label for="default-container">
<input type="radio" name="_generate_content_area" id="default-container" <?php checked( get_post_meta( get_the_ID(), '_generate_content_area', true ), '' ); ?> value="">
<?php esc_html_e( 'Default', 'gp-premium' ); ?>
</label>
</div>
<div class="layout-radio-item">
<label for="full-width-container">
<input type="radio" name="_generate_content_area" id="full-width-container" <?php checked( get_post_meta( get_the_ID(), '_generate_content_area', true ), 'full-width' ); ?> value="full-width">
<?php esc_html_e( 'Full Width (no padding)', 'gp-premium' ); ?>
</label>
</div>
<div class="layout-radio-item">
<label for="contained-container">
<input type="radio" name="_generate_content_area" id="contained-container" <?php checked( get_post_meta( get_the_ID(), '_generate_content_area', true ), 'contained' ); ?> value="contained">
<?php echo esc_html_x( 'Contained (no padding)', 'Width', 'gp-premium' ); ?>
</label>
</div>
</td>
</tr>
<tr class="generate-element-row">
<td class="generate-element-row-heading">
<label for="_generate_content_width"><?php _e( 'Content Width', 'gp-premium' ); ?></label>
</td>
<td class="generate-element-row-content">
<input type="number" id="_generate_content_width" name="_generate_content_width" value="<?php echo esc_attr( get_post_meta( get_the_ID(), '_generate_content_width', true ) ); ?>">
<span class="unit">px</span>
</td>
</tr>
</tbody>
</table>
<?php endif; ?>
<table class="generate-elements-settings" data-tab="display-rules" style="<?php echo 'block' !== $type ? 'display: none;' : ''; ?>">
<tbody>
<tr class="generate-element-row">
<td class="generate-element-row-heading">
<label><?php _e( 'Location', 'gp-premium' ); ?></label>
<span class="tip" data-balloon="<?php esc_attr_e( 'Choose when this element should display.', 'gp-premium' ); ?>" data-balloon-pos="down">?</span>
</td>
<td class="generate-element-row-content">
<?php
$display_conditionals = get_post_meta( get_the_ID(), '_generate_element_display_conditions', true );
$conditions = GeneratePress_Conditions::get_conditions();
if ( $display_conditionals ) {
foreach ( $display_conditionals as $field => $value ) {
$type = explode( ':', $value['rule'] );
if ( in_array( 'post', $type ) || in_array( 'taxonomy', $type ) ) {
$show = true;
} else {
$show = false;
}
?>
<div class="condition <?php echo $show ? 'generate-elements-rule-objects-visible' : ''; ?>">
<select class="condition-select" name="display-condition[]">
<option value=""><?php esc_attr_e( 'Choose...', 'gp-premium' ); ?></option>
<?php foreach ( $conditions as $type ) { ?>
<optgroup label="<?php echo esc_html( $type['label'] ); ?>">
<?php
foreach ( $type['locations'] as $id => $label ) {
printf(
'<option value="%1$s" %2$s>%3$s</option>',
esc_attr( $id ),
selected( $value['rule'], $id ),
esc_html( $label )
);
}
?>
</optgroup>
<?php } ?>
</select>
<select class="condition-object-select" data-saved-value="<?php echo isset( $value['object'] ) ? esc_html( $value['object'] ) : ''; ?>" name="display-condition-object[]">
<option value="0"></option>
</select>
<button class="remove-condition"><span class="screen-reader-text"><?php _e( 'Remove', 'gp-premium' ); ?></span></button>
</div>
<?php
}
} else {
?>
<div class="condition">
<select class="condition-select" name="display-condition[]">
<option value=""><?php esc_attr_e( 'Choose...', 'gp-premium' ); ?></option>
<?php foreach ( $conditions as $type ) { ?>
<optgroup label="<?php echo esc_html( $type['label'] ); ?>">
<?php
foreach ( $type['locations'] as $id => $label ) {
printf(
'<option value="%1$s">%2$s</option>',
esc_attr( $id ),
esc_html( $label )
);
}
?>
</optgroup>
<?php } ?>
</select>
<select class="condition-object-select" name="display-condition-object[]">
<option value="0"></option>
</select>
<button class="remove-condition"><span class="screen-reader-text"><?php _e( 'Remove', 'gp-premium' ); ?></span></button>
</div>
<?php
}
?>
<div class="condition hidden screen-reader-text">
<select class="condition-select" name="display-condition[]">
<option value=""><?php esc_attr_e( 'Choose...', 'gp-premium' ); ?></option>
<?php foreach ( $conditions as $type ) { ?>
<optgroup label="<?php echo esc_html( $type['label'] ); ?>">
<?php
foreach ( $type['locations'] as $id => $label ) {
printf(
'<option value="%1$s">%2$s</option>',
esc_attr( $id ),
esc_html( $label )
);
}
?>
</optgroup>
<?php } ?>
</select>
<select class="condition-object-select" name="display-condition-object[]">
<option value="0"></option>
</select>
<button class="remove-condition"><span class="screen-reader-text"><?php _e( 'Remove', 'gp-premium' ); ?></span></button>
</div>
<button class="button add-condition"><?php _e( 'Add Location Rule', 'gp-premium' ); ?></button>
</td>
</tr>
<tr class="generate-element-row">
<td class="generate-element-row-heading">
<label><?php _e( 'Exclude', 'gp-premium' ); ?></label>
<span class="tip" data-balloon="<?php esc_attr_e( 'Choose when this element should not display.', 'gp-premium' ); ?>" data-balloon-pos="down">?</span>
</td>
<td class="generate-element-row-content">
<?php
$exclude_conditionals = get_post_meta( get_the_ID(), '_generate_element_exclude_conditions', true );
$conditions = GeneratePress_Conditions::get_conditions();
if ( $exclude_conditionals ) {
foreach ( $exclude_conditionals as $field => $value ) {
$type = explode( ':', $value['rule'] );
if ( in_array( 'post', $type ) || in_array( 'taxonomy', $type ) ) {
$show = true;
} else {
$show = false;
}
?>
<div class="condition <?php echo $show ? 'generate-elements-rule-objects-visible' : ''; ?>">
<select class="condition-select" name="exclude-condition[]">
<option value=""><?php esc_attr_e( 'Choose...', 'gp-premium' ); ?></option>
<?php foreach ( $conditions as $type ) { ?>
<optgroup label="<?php echo esc_html( $type['label'] ); ?>">
<?php
foreach ( $type['locations'] as $id => $label ) {
printf(
'<option value="%1$s" %2$s>%3$s</option>',
esc_attr( $id ),
selected( $value['rule'], $id ),
esc_html( $label )
);
}
?>
</optgroup>
<?php } ?>
</select>
<select class="condition-object-select" data-saved-value="<?php echo isset( $value['object'] ) ? esc_html( $value['object'] ) : ''; ?>" name="exclude-condition-object[]">
<option value="0"></option>
</select>
<button class="remove-condition"><span class="screen-reader-text"><?php _e( 'Remove', 'gp-premium' ); ?></span></button>
</div>
<?php
}
} else {
?>
<div class="condition">
<select class="condition-select" name="exclude-condition[]">
<option value=""><?php esc_attr_e( 'Choose...', 'gp-premium' ); ?></option>
<?php
foreach ( $conditions as $type ) {
?>
<optgroup label="<?php echo esc_html( $type['label'] ); ?>">
<?php
foreach ( $type['locations'] as $id => $label ) {
printf(
'<option value="%1$s">%2$s</option>',
esc_attr( $id ),
esc_html( $label )
);
}
?>
</optgroup>
<?php } ?>
</select>
<select class="condition-object-select" name="exclude-condition-object[]">
<option value="0"></option>
</select>
<button class="remove-condition"><span class="screen-reader-text"><?php _e( 'Remove', 'gp-premium' ); ?></span></button>
</div>
<?php
}
?>
<div class="condition hidden screen-reader-text">
<select class="condition-select" name="exclude-condition[]">
<option value=""><?php esc_attr_e( 'Choose...', 'gp-premium' ); ?></option>
<?php
foreach ( $conditions as $type ) {
?>
<optgroup label="<?php echo esc_html( $type['label'] ); ?>">
<?php
foreach ( $type['locations'] as $id => $label ) {
printf(
'<option value="%1$s">%2$s</option>',
esc_attr( $id ),
esc_html( $label )
);
}
?>
</optgroup>
<?php } ?>
</select>
<select class="condition-object-select" name="exclude-condition-object[]">
<option value="0"></option>
</select>
<button class="remove-condition"><span class="screen-reader-text"><?php _e( 'Remove', 'gp-premium' ); ?></span></button>
</div>
<button class="button add-condition"><?php _e( 'Add Exclusion Rule', 'gp-premium' ); ?></button>
</td>
</tr>
<tr class="generate-element-row">
<td class="generate-element-row-heading">
<label><?php _e( 'Users', 'gp-premium' ); ?></label>
<span class="tip" data-balloon="<?php esc_attr_e( 'Display this element for specific user roles.', 'gp-premium' ); ?>" data-balloon-pos="down">?</span>
</td>
<td class="generate-element-row-content">
<?php
$user_conditionals = get_post_meta( get_the_ID(), '_generate_element_user_conditions', true );
$conditions = GeneratePress_Conditions::get_user_conditions();
if ( $user_conditionals ) {
foreach ( $user_conditionals as $field => $value ) {
?>
<div class="condition">
<select class="condition-select" name="user-condition[]">
<option value=""><?php esc_attr_e( 'Choose...', 'gp-premium' ); ?></option>
<?php
foreach ( $conditions as $type ) {
?>
<optgroup label="<?php echo esc_html( $type['label'] ); ?>">
<?php
foreach ( $type['rules'] as $id => $label ) {
printf(
'<option value="%1$s" %2$s>%3$s</option>',
esc_attr( $id ),
selected( $value, $id ),
esc_html( $label )
);
}
?>
</optgroup>
<?php } ?>
</select>
<button class="remove-condition"><span class="screen-reader-text"><?php _e( 'Remove', 'gp-premium' ); ?></span></button>
</div>
<?php
}
} else {
?>
<div class="condition">
<select class="condition-select" name="user-condition[]">
<option value=""><?php esc_attr_e( 'Choose...', 'gp-premium' ); ?></option>
<?php
foreach ( $conditions as $type ) {
?>
<optgroup label="<?php echo esc_html( $type['label'] ); ?>">
<?php
foreach ( $type['rules'] as $id => $label ) {
printf(
'<option value="%1$s">%2$s</option>',
esc_attr( $id ),
esc_html( $label )
);
}
?>
</optgroup>
<?php } ?>
</select>
<button class="remove-condition"><span class="screen-reader-text"><?php _e( 'Remove', 'gp-premium' ); ?></span></button>
</div>
<?php
}
?>
<div class="condition hidden screen-reader-text">
<select class="condition-select" name="user-condition[]">
<option value=""><?php esc_attr_e( 'Choose...', 'gp-premium' ); ?></option>
<?php
foreach ( $conditions as $type ) {
?>
<optgroup label="<?php echo esc_html( $type['label'] ); ?>">
<?php
foreach ( $type['rules'] as $id => $label ) {
printf(
'<option value="%1$s">%2$s</option>',
esc_attr( $id ),
esc_html( $label )
);
}
?>
</optgroup>
<?php } ?>
</select>
<button class="remove-condition"><span class="screen-reader-text"><?php _e( 'Remove', 'gp-premium' ); ?></span></button>
</div>
<button class="button add-condition"><?php _e( 'Add User Rule', 'gp-premium' ); ?></button>
</td>
</tr>
<tr class="generate-element-row" <?php echo ! function_exists( 'pll_get_post_language' ) ? 'style="display: none;"' : ''; ?>>
<td class="generate-element-row-heading">
<label for="_generate_element_ignore_languages"><?php _e( 'Ignore Languages', 'gp-premium' ); ?></label>
<span class="tip" data-balloon="<?php esc_attr_e( 'Show this Element to all languages.', 'gp-premium' ); ?>" data-balloon-pos="up">?</span>
</td>
<td class="generate-element-row-content">
<input type="checkbox" name="_generate_element_ignore_languages" id="_generate_element_ignore_languages" value="true" <?php checked( get_post_meta( get_the_ID(), '_generate_element_ignore_languages', true ), 'true' ); ?> />
</td>
</tr>
</tbody>
</table>
<table class="generate-elements-settings" data-type="all" data-tab="internal-notes" style="display: none;">
<tbody>
<tr id="hook-row" class="generate-element-row">
<td class="generate-element-row-content">
<textarea id="_generate_element_internal_notes" name="_generate_element_internal_notes"><?php echo esc_textarea( get_post_meta( get_the_ID(), '_generate_element_internal_notes', true ) ); ?></textarea>
<p style="margin: 5px 0 0;"><?php _e( 'Internal notes can be helpful to remember why this element was added.', 'gp-premium' ); ?></p>
</td>
</tr>
</tbody>
</table>
</div>
<?php
}
/**
* Save all of our metabox values.
*
* @since 1.7
*
* @param int $post_id The ID of the post being saved.
*/
public function save( $post_id ) {
$is_autosave = wp_is_post_autosave( $post_id );
$is_revision = wp_is_post_revision( $post_id );
$is_valid_nonce = ( isset( $_POST['generate_elements_nonce'] ) && wp_verify_nonce( $_POST['generate_elements_nonce'], basename( __FILE__ ) ) ) ? true : false;
// Exits script depending on save status.
if ( $is_autosave || $is_revision || ! $is_valid_nonce ) {
return;
}
// Check that the logged in user has permission to edit this post.
if ( ! current_user_can( 'edit_post', $post_id ) ) {
return $post_id;
}
if ( ! isset( $_POST['_generate_element_type'] ) ) {
return $post_id;
}
// Save the type of element.
$type_key = '_generate_element_type';
$type_value = sanitize_key( $_POST[ $type_key ] ); // phpcs:ignore -- Checked for existence above.
if ( $type_value ) {
update_post_meta( $post_id, $type_key, $type_value );
} else {
delete_post_meta( $post_id, $type_key );
}
// Content.
if ( isset( $_POST['_generate_element_content'] ) ) {
$key = '_generate_element_content';
if ( current_user_can( 'unfiltered_html' ) ) {
$value = $_POST[ $key ];
} else {
$value = wp_kses_post( $_POST[ $key ] );
}
if ( $value ) {
update_post_meta( $post_id, $key, $value );
} else {
delete_post_meta( $post_id, $key );
}
}
// Save Hooks type.
if ( 'hook' === $type_value ) {
$hook_values = array(
'_generate_hook' => 'text',
'_generate_custom_hook' => 'text',
'_generate_hook_priority' => 'number',
);
if ( 'hook' === $type_value ) {
$hook_values['_generate_hook_disable_site_header'] = 'key';
$hook_values['_generate_hook_disable_site_footer'] = 'key';
$hook_values['_generate_hook_execute_shortcodes'] = 'key';
$hook_values['_generate_hook_execute_php'] = 'key';
}
// We don't want people to be able to use these hooks.
$blacklist = array(
'muplugins_loaded',
'registered_taxonomy',
'plugins_loaded',
'setup_theme',
'after_setup_theme',
'init',
'widgets_init',
'wp_loaded',
'pre_get_posts',
'wp',
'template_redirect',
'get_header',
'wp_enqueue_scripts',
'the_post',
'dynamic_sidebar',
'get_footer',
'get_sidebar',
'wp_print_footer_scripts',
'shutdown',
);
foreach ( $hook_values as $key => $type ) {
$value = false;
if ( isset( $_POST[ $key ] ) ) {
// Bail if we're using a blacklisted hook.
if ( '_generate_custom_hook' === $key ) {
if ( in_array( $_POST[ $key ], $blacklist ) ) {
continue;
}
}
if ( 'number' === $type ) {
$value = absint( $_POST[ $key ] );
} elseif ( 'key' === $type ) {
$value = sanitize_key( $_POST[ $key ] );
} else {
$value = sanitize_text_field( $_POST[ $key ] );
}
// Need to temporarily change the $value so it returns true.
if ( '_generate_hook_priority' === $key ) {
if ( '0' === $_POST[ $key ] ) {
$value = 'zero';
}
}
}
if ( $value ) {
if ( 'zero' === $value ) {
$value = '0';
}
update_post_meta( $post_id, $key, $value );
} else {
delete_post_meta( $post_id, $key );
}
}
}
// Page Header type.
if ( 'header' === $type_value ) {
$hero_values = array(
'_generate_hero_custom_classes' => 'attribute',
'_generate_hero_container' => 'text',
'_generate_hero_inner_container' => 'text',
'_generate_hero_horizontal_alignment' => 'text',
'_generate_hero_full_screen' => 'key',
'_generate_hero_vertical_alignment' => 'text',
'_generate_hero_padding_top' => 'number',
'_generate_hero_padding_top_unit' => 'text',
'_generate_hero_padding_right' => 'number',
'_generate_hero_padding_right_unit' => 'text',
'_generate_hero_padding_bottom' => 'number',
'_generate_hero_padding_bottom_unit' => 'text',
'_generate_hero_padding_left' => 'number',
'_generate_hero_padding_left_unit' => 'text',
'_generate_hero_padding_top_mobile' => 'number',
'_generate_hero_padding_top_unit_mobile' => 'text',
'_generate_hero_padding_right_mobile' => 'number',
'_generate_hero_padding_right_unit_mobile' => 'text',
'_generate_hero_padding_bottom_mobile' => 'number',
'_generate_hero_padding_bottom_unit_mobile' => 'text',
'_generate_hero_padding_left_mobile' => 'number',
'_generate_hero_padding_left_unit_mobile' => 'text',
'_generate_hero_background_image' => 'key',
'_generate_hero_disable_featured_image' => 'key',
'_generate_hero_background_color' => 'color',
'_generate_hero_text_color' => 'color',
'_generate_hero_link_color' => 'color',
'_generate_hero_background_link_color_hover' => 'color',
'_generate_hero_background_overlay' => 'key',
'_generate_hero_background_position' => 'text',
'_generate_hero_background_parallax' => 'key',
'_generate_site_header_merge' => 'key',
'_generate_site_header_height' => 'number',
'_generate_site_header_height_mobile' => 'number',
'_generate_navigation_colors' => 'key',
'_generate_site_logo' => 'number',
'_generate_retina_logo' => 'number',
'_generate_navigation_logo' => 'number',
'_generate_mobile_logo' => 'number',
'_generate_navigation_location' => 'key',
'_generate_site_header_background_color' => 'text',
'_generate_site_header_title_color' => 'text',
'_generate_site_header_tagline_color' => 'text',
'_generate_navigation_background_color' => 'text',
'_generate_navigation_text_color' => 'text',
'_generate_navigation_background_color_hover' => 'text',
'_generate_navigation_text_color_hover' => 'text',
'_generate_navigation_background_color_current' => 'text',
'_generate_navigation_text_color_current' => 'text',
);
foreach ( $hero_values as $key => $type ) {
$value = false;
if ( isset( $_POST[ $key ] ) ) {
if ( 'number' === $type ) {
$value = absint( $_POST[ $key ] );
} elseif ( 'key' === $type ) {
$value = sanitize_key( $_POST[ $key ] );
} elseif ( 'attribute' === $type ) {
$value = esc_attr( $_POST[ $key ] );
} else {
$value = sanitize_text_field( $_POST[ $key ] );
}
}
if (
'_generate_hero_padding_top_mobile' === $key ||
'_generate_hero_padding_right_mobile' === $key ||
'_generate_hero_padding_bottom_mobile' === $key ||
'_generate_hero_padding_left_mobile' === $key
) {
if ( '0' === $_POST[ $key ] ) {
$value = 'zero';
}
}
if ( $value ) {
if ( 'zero' === $value ) {
$value = '0'; // String on purpose.
}
update_post_meta( $post_id, $key, $value );
} else {
delete_post_meta( $post_id, $key );
}
}
}
// Save Layout type.
if ( 'layout' === $type_value ) {
$layout_values = array(
'_generate_sidebar_layout' => 'key',
'_generate_footer_widgets' => 'key',
'_generate_disable_site_header' => 'key',
'_generate_disable_mobile_header' => 'key',
'_generate_disable_top_bar' => 'key',
'_generate_disable_primary_navigation' => 'key',
'_generate_disable_secondary_navigation' => 'key',
'_generate_disable_featured_image' => 'key',
'_generate_disable_content_title' => 'key',
'_generate_disable_footer' => 'key',
'_generate_content_area' => 'key',
'_generate_content_width' => 'number',
);
foreach ( $layout_values as $key => $type ) {
$value = false;
if ( isset( $_POST[ $key ] ) ) {
if ( 'number' === $type ) {
$value = absint( $_POST[ $key ] );
} elseif ( 'key' === $type ) {
$value = sanitize_key( $_POST[ $key ] );
} else {
$value = sanitize_text_field( $_POST[ $key ] );
}
}
if ( $value ) {
update_post_meta( $post_id, $key, $value );
} else {
delete_post_meta( $post_id, $key );
}
}
}
$ignore_languages = false;
if ( isset( $_POST['_generate_element_ignore_languages'] ) ) {
$ignore_languages = sanitize_key( $_POST['_generate_element_ignore_languages'] );
}
if ( $ignore_languages ) {
update_post_meta( $post_id, '_generate_element_ignore_languages', $ignore_languages );
} else {
delete_post_meta( $post_id, '_generate_element_ignore_languages' );
}
// Display conditions.
$conditions = get_post_meta( $post_id, '_generate_element_display_conditions', true );
$new_conditions = array();
$rules = $_POST['display-condition'];
$objects = $_POST['display-condition-object'];
$count = count( $rules );
for ( $i = 0; $i < $count; $i++ ) {
if ( '' !== $rules[ $i ] ) {
if ( in_array( $rules[ $i ], $rules ) ) {
$new_conditions[ $i ]['rule'] = sanitize_text_field( $rules[ $i ] );
$new_conditions[ $i ]['object'] = sanitize_key( $objects[ $i ] );
} else {
$new_conditions[ $i ]['rule'] = '';
$new_conditions[ $i ]['object'] = '';
}
}
}
if ( 'block' === $type_value ) {
$dynamic_css_posts = get_option( 'generateblocks_dynamic_css_posts', array() );
if ( $dynamic_css_posts ) {
foreach ( $new_conditions as $condition ) {
if ( $condition['object'] && isset( $dynamic_css_posts[ $condition['object'] ] ) ) {
unset( $dynamic_css_posts[ $condition['object'] ] );
}
if ( ! $condition['object'] ) {
$dynamic_css_posts = array();
break;
}
}
update_option( 'generateblocks_dynamic_css_posts', $dynamic_css_posts );
}
}
if ( ! empty( $new_conditions ) && $new_conditions !== $conditions ) {
update_post_meta( $post_id, '_generate_element_display_conditions', $new_conditions );
} elseif ( empty( $new_conditions ) && $conditions ) {
delete_post_meta( $post_id, '_generate_element_display_conditions', $conditions );
}
// Exclude conditions.
$exclude_conditions = get_post_meta( $post_id, '_generate_element_exclude_conditions', true );
$new_exclude_conditions = array();
$exclude_rules = $_POST['exclude-condition'];
$exclude_objects = $_POST['exclude-condition-object'];
$exclude_count = count( $exclude_rules );
for ( $i = 0; $i < $exclude_count; $i++ ) {
if ( '' !== $exclude_rules[ $i ] ) {
if ( in_array( $exclude_rules[ $i ], $exclude_rules ) ) {
$new_exclude_conditions[ $i ]['rule'] = sanitize_text_field( $exclude_rules[ $i ] );
$new_exclude_conditions[ $i ]['object'] = sanitize_key( $exclude_objects[ $i ] );
} else {
$new_exclude_conditions[ $i ]['rule'] = '';
$new_exclude_conditions[ $i ]['object'] = '';
}
}
}
if ( ! empty( $new_exclude_conditions ) && $new_exclude_conditions !== $exclude_conditions ) {
update_post_meta( $post_id, '_generate_element_exclude_conditions', $new_exclude_conditions );
} elseif ( empty( $new_exclude_conditions ) && $exclude_conditions ) {
delete_post_meta( $post_id, '_generate_element_exclude_conditions', $exclude_conditions );
}
// User conditions.
$user_conditions = get_post_meta( $post_id, '_generate_element_user_conditions', true );
$new_user_conditions = array();
$user_rules = $_POST['user-condition'];
$user_count = count( $user_rules );
for ( $i = 0; $i < $user_count; $i++ ) {
if ( '' !== $user_rules[ $i ] ) {
if ( in_array( $user_rules[ $i ], $user_rules ) ) {
$new_user_conditions[ $i ] = sanitize_text_field( $user_rules[ $i ] );
} else {
$new_user_conditions[ $i ] = '';
}
}
}
if ( ! empty( $new_user_conditions ) && $new_user_conditions !== $user_conditions ) {
update_post_meta( $post_id, '_generate_element_user_conditions', $new_user_conditions );
} elseif ( empty( $new_user_conditions ) && $user_conditions ) {
delete_post_meta( $post_id, '_generate_element_user_conditions', $user_conditions );
}
// Internal notes.
$notes_key = '_generate_element_internal_notes';
if ( isset( $_POST[ $notes_key ] ) ) {
if ( function_exists( 'sanitize_textarea_field' ) ) {
$notes_value = sanitize_textarea_field( $_POST[ $notes_key ] );
} else {
$notes_value = sanitize_text_field( $_POST[ $notes_key ] );
}
if ( $notes_value ) {
update_post_meta( $post_id, $notes_key, $notes_value );
} else {
delete_post_meta( $post_id, $notes_key );
}
}
}
/**
* Get terms of a set taxonomy.
*
* @since 1.7
*/
public function get_terms() {
check_ajax_referer( 'generate-elements-location', 'nonce' );
$current_user_can = 'manage_options';
if ( apply_filters( 'generate_elements_metabox_ajax_allow_editors', false ) ) {
$current_user_can = 'edit_posts';
}
if ( ! current_user_can( $current_user_can ) ) {
return;
}
if ( ! isset( $_POST['id'] ) ) {
return;
}
$tax_id = sanitize_text_field( $_POST['id'] );
echo wp_json_encode( self::get_taxonomy_terms( $tax_id ) );
die();
}
/**
* Get all posts inside a specific post type.
*
* @since 1.7
*/
public function get_posts() {
check_ajax_referer( 'generate-elements-location', 'nonce' );
$current_user_can = 'manage_options';
if ( apply_filters( 'generate_elements_metabox_ajax_allow_editors', false ) ) {
$current_user_can = 'edit_posts';
}
if ( ! current_user_can( $current_user_can ) ) {
return;
}
if ( ! isset( $_POST['id'] ) ) {
return;
}
$post_type = sanitize_text_field( $_POST['id'] );
echo wp_json_encode( self::get_post_type_posts( $post_type ) );
die();
}
/**
* Get all of our posts and terms in one go on load.
*
* @since 2.0.0
*/
public function get_all_objects() {
check_ajax_referer( 'generate-elements-location', 'nonce' );
$current_user_can = 'manage_options';
if ( apply_filters( 'generate_elements_metabox_ajax_allow_editors', false ) ) {
$current_user_can = 'edit_posts';
}
if ( ! current_user_can( $current_user_can ) ) {
return;
}
if ( ! isset( $_POST['posts'] ) && ! isset( $_POST['terms'] ) ) {
return;
}
$posts = array();
$terms = array();
if ( ! empty( $_POST['posts'] ) ) {
$posts = array_map( 'sanitize_text_field', $_POST['posts'] );
}
if ( ! empty( $_POST['terms'] ) ) {
$terms = array_map( 'sanitize_text_field', $_POST['terms'] );
}
$all_posts = self::get_post_type_posts( $posts );
$all_terms = self::get_taxonomy_terms( $terms );
echo wp_json_encode( array_merge( $all_posts, $all_terms ) );
die();
}
/**
* Look up posts inside a post type.
*
* @since 1.7
*
* @param string|array $post_type The post type to look up.
* @return array
*/
public static function get_post_type_posts( $post_type ) {
if ( ! is_array( $post_type ) ) {
$post_type = array( $post_type );
}
$data = array();
foreach ( $post_type as $type ) {
global $wpdb;
$post_status = array( 'publish', 'future', 'draft', 'pending', 'private' );
$object = get_post_type_object( $type );
$data[ $type ] = array(
'type' => 'posts',
'postType' => $type,
'label' => $object->label,
'objects' => array(),
);
if ( 'attachment' === $type ) {
$posts = $wpdb->get_results( $wpdb->prepare( "SELECT ID, post_title from $wpdb->posts where post_type = %s ORDER BY post_title", $type ) );
} else {
$format = implode( ', ', array_fill( 0, count( $post_status ), '%s' ) );
$query = sprintf( "SELECT ID, post_title from $wpdb->posts where post_type = '%s' AND post_status IN(%s) ORDER BY post_title", $type, $format );
// @codingStandardsIgnoreLine
$posts = $wpdb->get_results( $wpdb->prepare( $query, $post_status ) );
}
foreach ( $posts as $post ) {
$title = ( '' !== $post->post_title ) ? esc_attr( $post->post_title ) : $type . '-' . $post->ID;
$data[ $type ]['objects'][] = array(
'id' => $post->ID,
'name' => $title,
);
}
}
return $data;
}
/**
* Get taxonomy terms for a specific taxonomy.
*
* @since 1.7
*
* @param int|array $tax_id The taxonomy ID.
* @return array
*/
public static function get_taxonomy_terms( $tax_id ) {
if ( ! is_array( $tax_id ) ) {
$tax_id = array( $tax_id );
}
$data = array();
foreach ( $tax_id as $id ) {
$tax = get_taxonomy( $id );
$terms = get_terms(
array(
'taxonomy' => $id,
'hide_empty' => false,
)
);
$data[ $id ] = array(
'type' => 'terms',
'taxonomy' => $id,
'label' => $tax->label,
'objects' => array(),
);
foreach ( $terms as $term ) {
$data[ $id ]['objects'][] = array(
'id' => $term->term_id,
'name' => esc_attr( $term->name ),
);
}
}
return $data;
}
/**
* Build our entire list of hooks to display.
*
* @since 1.7
*
* @return array Our list of hooks.
*/
public static function get_available_hooks() {
return GeneratePress_Elements_Helper::get_available_hooks();
}
/**
* Add available template tags to Header Elements.
*
* @since 1.7
*/
public static function template_tags() {
?>
<input type="text" readonly="readonly" value="{{post_title}}" />
<p class="decription" style="margin-top:0;opacity:0.8;font-size:85%;">
<?php _e( 'The content title of the current post/taxonomy.', 'gp-premium' ); ?>
</p>
<input type="text" readonly="readonly" value="{{post_date}}" />
<p class="decription" style="margin-top:0;opacity:0.8;font-size:85%;">
<?php _e( 'The published date of the current post.', 'gp-premium' ); ?>
</p>
<input type="text" readonly="readonly" value="{{post_author}}" />
<p class="decription" style="margin-top:0;opacity:0.8;font-size:85%;">
<?php _e( 'The author of the current post.', 'gp-premium' ); ?>
</p>
<input type="text" readonly="readonly" value="{{post_terms.taxonomy}}" />
<p class="decription" style="margin-top:0;opacity:0.8;font-size:85%;">
<?php _e( 'The terms attached to the chosen taxonomy (category, post_tag, product_cat).', 'gp-premium' ); ?>
</p>
<input type="text" readonly="readonly" value='{{custom_field.name}}' />
<p class="decription" style="margin-top:0;opacity:0.8;font-size:85%;">
<?php _e( 'Custom post meta. Replace "name" with the name of your custom field.', 'gp-premium' ); ?>
</p>
<?php
}
}
GeneratePress_Elements_Metabox::get_instance();