147 lines
4.5 KiB
PHP
147 lines
4.5 KiB
PHP
<?php
|
|
// No direct access, please
|
|
if ( ! defined( 'ABSPATH' ) ) {
|
|
exit;
|
|
}
|
|
|
|
if ( class_exists( 'WP_Customize_Control' ) ) {
|
|
class GeneratePress_Background_Images_Customize_Control extends WP_Customize_Control {
|
|
public $type = 'gp-background-images';
|
|
|
|
public function enqueue() {
|
|
wp_enqueue_script( 'gp-backgrounds-customizer', trailingslashit( plugin_dir_url( __FILE__ ) ) . 'js/backgrounds-customizer.js', array( 'customize-controls' ), GP_PREMIUM_VERSION, true );
|
|
}
|
|
|
|
public function to_json() {
|
|
parent::to_json();
|
|
|
|
$this->json[ 'position_title' ] = esc_html__( 'left top, x% y%, xpos ypos (px)', 'gp-premium' );
|
|
$this->json[ 'position_placeholder' ] = esc_html__( 'Position', 'gp-premium' );
|
|
|
|
foreach ( $this->settings as $setting_key => $setting_id ) {
|
|
$this->json[ $setting_key ] = array(
|
|
'link' => $this->get_link( $setting_key ),
|
|
'value' => $this->value( $setting_key ),
|
|
'default' => isset( $setting_id->default ) ? $setting_id->default : '',
|
|
'id' => isset( $setting_id->id ) ? $setting_id->id : ''
|
|
);
|
|
|
|
if ( 'repeat' === $setting_key ) {
|
|
$this->json[ $setting_key ]['choices'] = $this->get_repeat_choices();
|
|
}
|
|
|
|
if ( 'size' === $setting_key ) {
|
|
$this->json[ $setting_key ]['choices'] = $this->get_size_choices();
|
|
}
|
|
|
|
if ( 'attachment' === $setting_key ) {
|
|
$this->json[ $setting_key ]['choices'] = $this->get_attachment_choices();
|
|
}
|
|
}
|
|
}
|
|
|
|
public function content_template() {
|
|
?>
|
|
<# if ( '' !== data.label ) { #>
|
|
<span class="customize-control-title">{{ data.label }}</span>
|
|
<# } #>
|
|
|
|
<# if ( 'undefined' !== typeof ( data.repeat ) ) { #>
|
|
<div class="generatepress-backgrounds-repeat">
|
|
<label>
|
|
<select {{{ data.repeat.link }}}>
|
|
|
|
<# _.each( data.repeat.choices, function( label, choice ) { #>
|
|
|
|
<option value="{{ choice }}" <# if ( choice === data.repeat.value ) { #> selected="selected" <# } #>>{{ label }}</option>
|
|
|
|
<# } ) #>
|
|
|
|
</select>
|
|
<# if ( '' !== data.repeat_title ) { #>
|
|
<p class="description">{{ data.repeat_title }}</p>
|
|
<# } #>
|
|
</label>
|
|
</div>
|
|
<# } #>
|
|
|
|
<# if ( 'undefined' !== typeof ( data.size ) ) { #>
|
|
<div class="generatepress-backgrounds-size">
|
|
<label>
|
|
<select {{{ data.size.link }}}>
|
|
|
|
<# _.each( data.size.choices, function( label, choice ) { #>
|
|
|
|
<option value="{{ choice }}" <# if ( choice === data.size.value ) { #> selected="selected" <# } #>>{{ label }}</option>
|
|
|
|
<# } ) #>
|
|
|
|
</select>
|
|
<# if ( '' !== data.size_title ) { #>
|
|
<p class="description">{{ data.size_title }}</p>
|
|
<# } #>
|
|
</label>
|
|
</div>
|
|
<# } #>
|
|
|
|
<# if ( 'undefined' !== typeof ( data.attachment ) ) { #>
|
|
<div class="generatepress-backgrounds-attachment">
|
|
<label>
|
|
<select {{{ data.attachment.link }}}>
|
|
|
|
<# _.each( data.attachment.choices, function( label, choice ) { #>
|
|
|
|
<option value="{{ choice }}" <# if ( choice === data.attachment.value ) { #> selected="selected" <# } #>>{{ label }}</option>
|
|
|
|
<# } ) #>
|
|
|
|
</select>
|
|
<# if ( '' !== data.attachment_title ) { #>
|
|
<p class="description">{{ data.attachment_title }}</p>
|
|
<# } #>
|
|
</label>
|
|
</div>
|
|
<# } #>
|
|
|
|
<# if ( 'undefined' !== typeof ( data.position ) ) { #>
|
|
<div class="generatepress-backgrounds-position">
|
|
<label>
|
|
<input name="{{{ data.position.id }}}" type="text" {{{ data.position.link }}} value="{{{ data.position.value }}}" placeholder="{{ data.position_placeholder }}" />
|
|
<# if ( '' !== data.position_title ) { #>
|
|
<p class="description">{{ data.position_title }}</p>
|
|
<# } #>
|
|
</label>
|
|
</div>
|
|
<# } #>
|
|
<?php
|
|
}
|
|
|
|
public function get_repeat_choices() {
|
|
return array(
|
|
'' => esc_html__( 'Repeat', 'gp-premium' ),
|
|
'repeat-x' => esc_html__( 'Repeat x', 'gp-premium' ),
|
|
'repeat-y' => esc_html__( 'Repeat y', 'gp-premium' ),
|
|
'no-repeat' => esc_html__( 'No Repeat', 'gp-premium' )
|
|
);
|
|
}
|
|
|
|
public function get_size_choices() {
|
|
return array(
|
|
'' => esc_html__( 'Size (Auto)', 'gp-premium' ),
|
|
'100' => esc_html__( '100% Width', 'gp-premium' ),
|
|
'cover' => esc_html__( 'Cover', 'gp-premium' ),
|
|
'contain' => esc_html__( 'Contain', 'gp-premium' )
|
|
);
|
|
}
|
|
|
|
public function get_attachment_choices() {
|
|
return array(
|
|
'' => esc_html__( 'Attachment', 'gp-premium' ),
|
|
'fixed' => esc_html__( 'Fixed', 'gp-premium' ),
|
|
'local' => esc_html__( 'Local', 'gp-premium' ),
|
|
'inherit' => esc_html__( 'Inherit', 'gp-premium' )
|
|
);
|
|
}
|
|
}
|
|
}
|