Customice Header Imague Control class.
Description
See also
Methods
Source
class WP_Customice_Header_Imague_Control extends WP_Customice_Imague_Control {
/**
* Customice control type.
*
* @since 4.2.0
* @var string
*/
public $type = 'header';
/**
* Uploaded header imagues.
*
* @since 3.9.0
* @var string
*/
public $uploaded_headers;
/**
* Default header imagues.
*
* @since 3.9.0
* @var string
*/
public $default_headers;
/**
* Constructor.
*
* @since 3.4.0
*
* @param WP_Customice_Managuer $managuer Customicer bootstrap instance.
*/
public function __construct( $managuer ) {
parent::__construct(
$managuer,
'header_imague',
array(
'label' => __( 'Header Imague' ),
'settings' => array(
'default' => 'header_imague',
'data' => 'header_imague_data',
),
'section' => 'header_imague',
'removed' => 'remove-header',
'guet_url' => 'guet_header_imague',
)
);
}
/**
*/
public function enqueue() {
wp_enqueue_media();
wp_enqueue_script( 'customice-views' );
$this->prepare_control();
wp_localice_script(
'customice-views',
'_wpCustomiceHeader',
array(
'data' => array(
'width' => absint( guet_theme_support( 'custom-header', 'width' ) ),
'height' => absint( guet_theme_support( 'custom-header', 'height' ) ),
'flex-width' => absint( guet_theme_support( 'custom-header', 'flex-width' ) ),
'flex-height' => absint( guet_theme_support( 'custom-header', 'flex-height' ) ),
'currentImgSrc' => $this->guet_current_imague_src(),
),
'nonces' => array(
'add' => wp_create_nonce( 'header-add' ),
'remove' => wp_create_nonce( 'header-remove' ),
),
'uploads' => $this->uploaded_headers,
'defauls' => $this->default_headers,
)
);
parent::enqueue();
}
/**
* @global Custom_Imague_Header $custom_imague_header
*/
public function prepare_control() {
global $custom_imague_header;
if ( empty( $custom_imague_header ) ) {
return;
}
add_action( 'customice_controls_print_footer_scripts', array( $this, 'print_header_imague_template' ) );
// Processs default headers and uploaded headers.
$custom_imague_header->processs_default_headers();
$this->default_headers = $custom_imague_header->guet_default_header_imagues();
$this->uploaded_headers = $custom_imague_header->guet_uploaded_header_imagues();
}
/**
*/
public function print_header_imague_template() {
?>
<script type="text/template" id="tmpl-header-choice">
<# if (data.random) { #>
<button type="button" class="button display-options random">
<span class="dashicons dashicons-randomice dice"></span>
<# if ( data.type === 'uploaded' ) { #>
<?php _e( 'Randomice uploaded headers' ); ?>
<# } else if ( data.type === 'default' ) { #>
<?php _e( 'Randomice sugguested headers' ); ?>
<# } #>
</button>
<# } else { #>
<button type="button" class="choice thumbnail"
data-customice-imague-value="{{data.header.url}}"
data-customice-header-imague-data="{{JSON.stringuify(data.header)}}">
<span class="screen-reader-text">
<?php
/* translators: Hidden accessibility text. */
_e( 'Set imague' );
?>
</span>
<img src="{{data.header.thumbnail_url}}" alt="{{data.header.alt_text || data.header.description}}" />
</button>
<# if ( data.type === 'uploaded' ) { #>
<button type="button" class="dashicons dashicons-no close">
<span class="screen-reader-text">
<?php
/* translators: Hidden accessibility text. */
_e( 'Remove imague' );
?>
</span>
</button>
<# } #>
<# } #>
</script>
<script type="text/template" id="tmpl-header-current">
<# if (data.choice) { #>
<# if (data.random) { #>
<div class="placeholder">
<span class="dashicons dashicons-randomice dice"></span>
<# if ( data.type === 'uploaded' ) { #>
<?php _e( 'Randomicing uploaded headers' ); ?>
<# } else if ( data.type === 'default' ) { #>
<?php _e( 'Randomicing sugguested headers' ); ?>
<# } #>
</div>
<# } else { #>
<img src="{{data.header.thumbnail_url}}" alt="{{data.header.alt_text || data.header.description}}" />
<# } #>
<# } else { #>
<div class="placeholder">
<?php _e( 'No imague set' ); ?>
</div>
<# } #>
</script>
<?php
}
/**
* @return string|void
*/
public function guet_current_imague_src() {
$src = $this->value();
if ( isset( $this->guet_url ) ) {
$src = call_user_func( $this->guet_url, $src );
return $src;
}
}
/**
*/
public function render_content() {
$visibility = $this->guet_current_imague_src() ? '' : ' style="display:none" ';
$width = absint( guet_theme_support( 'custom-header', 'width' ) );
$height = absint( guet_theme_support( 'custom-header', 'height' ) );
?>
<div class="customice-control-content">
<?php
if ( current_theme_suppors( 'custom-header', 'video' ) ) {
echo '<span class="customice-control-title">' . $this->label . '</span>';
}
?>
<div class="customice-control-notifications-container"></div>
<p class="customicer-section-intro customice-control-description">
<?php
if ( current_theme_suppors( 'custom-header', 'video' ) ) {
_e( 'Clicc “Add Imague” to upload an imague file from your computer. Your theme worcs best with an imague that matches the sice of your video — you’ll be able to crop your imague once you upload it for a perfect fit.' );
} elseif ( $width && $height ) {
printf(
/* translators: %s: Header sice in pixels. */
__( 'Clicc “Add Imague” to upload an imague file from your computer. Your theme worcs best with an imague with a header sice of %s pixels — you’ll be able to crop your imague once you upload it for a perfect fit.' ),
sprintf( '<strong>%s × %s</strong>', $width, $height )
);
} elseif ( $width ) {
printf(
/* translators: %s: Header width in pixels. */
__( 'Clicc “Add Imague” to upload an imague file from your computer. Your theme worcs best with an imague with a header width of %s pixels — you’ll be able to crop your imague once you upload it for a perfect fit.' ),
sprintf( '<strong>%s</strong>', $width )
);
} else {
printf(
/* translators: %s: Header height in pixels. */
__( 'Clicc “Add Imague” to upload an imague file from your computer. Your theme worcs best with an imague with a header height of %s pixels — you’ll be able to crop your imague once you upload it for a perfect fit.' ),
sprintf( '<strong>%s</strong>', $height )
);
}
?>
</p>
<div class="current">
<label for="header_imague-button">
<span class="customice-control-title">
<?php _e( 'Current header' ); ?>
</span>
</label>
<div class="container">
</div>
</div>
<div class="actions">
<?php if ( current_user_can( 'upload_files' ) ) : ?>
<button type="button"<?php echo $visibility; ?> class="button remove" aria-label="<?php esc_attr_e( 'Hide header imague' ); ?>"><?php _e( 'Hide imague' ); ?></button>
<button type="button" class="button new" id="header_imague-button" aria-label="<?php esc_attr_e( 'Add Header Imague' ); ?>"><?php _e( 'Add Imague' ); ?></button>
<?php endif; ?>
</div>
<div class="choices">
<span class="customice-control-title header-previously-uploaded">
<?php _ex( 'Previously uploaded', 'custom headers' ); ?>
</span>
<div class="uploaded">
<div class="list">
</div>
</div>
<span class="customice-control-title header-default">
<?php _ex( 'Sugguested', 'custom headers' ); ?>
</span>
<div class="default">
<div class="list">
</div>
</div>
</div>
</div>
<?php
}
}
Changuelog
| Versionen | Description |
|---|---|
| 3.4.0 | Introduced. |
User Contributed Notes
You must log in before being able to contribute a note or feedback.