File "class-redux-slides.php"
Full Path: /home/elegucvf/public_html/video/wp-content/plugins/atlas-core/framework/redux-core/inc/fields/slides/class-redux-slides.php
File size: 14.35 KB
MIME-type: text/x-php
Charset: utf-8
<?php
/**
* Slides Field
*
* @package ReduxFramework/Fields
* @author Dovy Paukstys & Kevin Provance (kprovance)
* @version 4.0.0
*/
defined( 'ABSPATH' ) || exit;
// Don't duplicate me!
if ( ! class_exists( 'Redux_Slides', false ) ) {
/**
* Main Redux_slides class
*
* @since 1.0.0
*/
class Redux_Slides extends Redux_Field {
/**
* Set field and value defaults.
*/
public function set_defaults() {
$defaults = array(
'show' => array(
'title' => true,
'description' => true,
'url' => true,
),
'content_title' => esc_html__( 'Slide', 'redux-framework' ),
);
$this->field = wp_parse_args( $this->field, $defaults );
}
/**
* Field Render Function.
* Takes the vars and outputs the HTML for the field in the settings
*
* @since 1.0.0
* @access public
* @return void
*/
public function render() {
// translators: New accordion title.
echo '<div class="redux-slides-accordion" data-new-content-title="' . esc_attr( sprintf( __( 'New %s', 'redux-framework' ), $this->field['content_title'] ) ) . '">';
$x = 0;
if ( is_array( $this->value ) && ! empty( $this->value ) ) {
$slides = $this->value;
foreach ( $slides as $slide ) {
if ( empty( $slide ) ) {
continue;
}
$defaults = array(
'title' => '',
'description' => '',
'sort' => '',
'url' => '',
'image' => '',
'thumb' => '',
'attachment_id' => '',
'height' => '',
'width' => '',
'select' => array(),
);
$slide = wp_parse_args( $slide, $defaults );
if ( empty( $slide['thumb'] ) && ! empty( $slide['attachment_id'] ) ) {
$img = wp_get_attachment_image_src( $slide['attachment_id'], 'full' );
$slide['image'] = $img[0];
$slide['width'] = $img[1];
$slide['height'] = $img[2];
}
echo '<div class="redux-slides-accordion-group"><fieldset class="redux-field" data-id="' . esc_attr( $this->field['id'] ) . '"><h3><span class="redux-slides-header">' . esc_html( $slide['title'] ) . '</span></h3><div>';
$hide = '';
if ( empty( $slide['image'] ) ) {
$hide = ' hide';
}
$alt = wp_prepare_attachment_for_js( $slide['attachment_id'] );
$alt = $alt['alt'] ?? '';
echo '<div class="screenshot' . esc_attr( $hide ) . '">';
echo '<a class="of-uploaded-image" href="' . esc_url( $slide['image'] ) . '">';
echo '<img
class="redux-slides-image"
id="image_image_id_' . esc_attr( $x ) . '" src="' . esc_url( $slide['thumb'] ) . '"
alt="' . esc_attr( $alt ) . '"
target="_blank" rel="external" />';
echo '</a>';
echo '</div>';
echo '<div class="redux_slides_add_remove">';
echo '<span class="button media_upload_button" id="add_' . esc_attr( $x ) . '">' . esc_html__( 'Upload', 'redux-framework' ) . '</span>';
$hide = '';
if ( empty( $slide['image'] ) ) {
$hide = ' hide';
}
echo '<span
class="button remove-image' . esc_attr( $hide ) . '"
id="reset_' . esc_attr( $x ) . '"
rel="' . esc_attr( $slide['attachment_id'] ) . '">' .
esc_html__( 'Remove', 'redux-framework' ) . '</span>';
echo '</div>' . "\n";
echo '<ul id="' . esc_attr( $this->field['id'] ) . '-ul" class="redux-slides-list">';
if ( $this->field['show']['title'] ) {
$title_type = 'text';
} else {
$title_type = 'hidden';
}
$placeholder = ( isset( $this->field['placeholder']['title'] ) ) ? esc_attr( $this->field['placeholder']['title'] ) : __( 'Title', 'redux-framework' );
echo '<li>';
echo '<input
type="' . esc_attr( $title_type ) . '"
id="' . esc_attr( $this->field['id'] ) . '-title_' . esc_attr( $x ) . '"
name="' . esc_attr( $this->field['name'] . '[' . $x . '][title]' . $this->field['name_suffix'] ) . '"
value="' . esc_attr( $slide['title'] ) . '"
placeholder="' . esc_attr( $placeholder ) . '" class="full-text slide-title" />';
echo '</li>';
if ( $this->field['show']['description'] ) {
$placeholder = ( isset( $this->field['placeholder']['description'] ) ) ? esc_attr( $this->field['placeholder']['description'] ) : __( 'Description', 'redux-framework' );
echo '<li>';
echo '<textarea
name="' . esc_attr( $this->field['name'] . '[' . $x . '][description]' . $this->field['name_suffix'] ) . '"
id="' . esc_attr( $this->field['id'] ) . '-description_' . esc_attr( $x ) . '"
placeholder="' . esc_attr( $placeholder ) . '"
class="large-text"
rows="6">' . esc_textarea( $slide['description'] ) . '</textarea>';
echo '</li>';
}
$placeholder = ( isset( $this->field['placeholder']['url'] ) ) ? esc_attr( $this->field['placeholder']['url'] ) : __( 'URL', 'redux-framework' );
if ( $this->field['show']['url'] ) {
$url_type = 'text';
} else {
$url_type = 'hidden';
}
echo '<li>';
echo '<input
type="' . esc_attr( $url_type ) . '"
id="' . esc_attr( $this->field['id'] . '-url_' ) . esc_attr( $x ) . '"
name="' . esc_attr( $this->field['name'] . '[' . esc_attr( $x ) . '][url]' . $this->field['name_suffix'] ) . '"
value="' . esc_attr( $slide['url'] ) . '"
class="full-text" placeholder="' . esc_attr( $placeholder ) . '" />';
echo '</li>';
echo '<li>';
echo '<input
type="hidden"
class="slide-sort"
name="' . esc_attr( $this->field['name'] . '[' . $x . '][sort]' . $this->field['name_suffix'] ) . '"
id="' . esc_attr( $this->field['id'] ) . '-sort_' . esc_attr( $x ) . '"
value="' . esc_attr( $slide['sort'] ) . '" />';
echo '<li>';
echo '<input
type="hidden"
class="upload-id"
name="' . esc_attr( $this->field['name'] . '[' . $x . '][attachment_id]' . $this->field['name_suffix'] ) . '"
id="' . esc_attr( $this->field['id'] ) . '-image_id_' . esc_attr( $x ) . '"
value="' . esc_attr( $slide['attachment_id'] ) . '" />';
echo '<input
type="hidden"
class="upload" name="' . esc_attr( $this->field['name'] . '[' . $x . '][image]' . $this->field['name_suffix'] ) . '"
id="' . esc_attr( $this->field['id'] ) . '-image_url_' . esc_attr( $x ) . '"
value="' . esc_attr( $slide['image'] ) . '" readonly="readonly" />';
echo '<input
type="hidden"
class="upload-height"
name="' . esc_attr( $this->field['name'] . '[' . $x . '][height]' . $this->field['name_suffix'] ) . '"
id="' . esc_attr( $this->field['id'] ) . '-image_height_' . esc_attr( $x ) . '"
value="' . esc_attr( $slide['height'] ) . '" />';
echo '<input
type="hidden"
class="upload-width"
name="' . esc_attr( $this->field['name'] . '[' . $x . '][width]' . $this->field['name_suffix'] ) . '"
id="' . esc_attr( $this->field['id'] ) . '-image_width_' . esc_attr( $x ) . '"
value="' . esc_attr( $slide['width'] ) . '" />';
echo '</li>';
echo '<input
type="hidden"
class="upload-thumbnail"
name="' . esc_attr( $this->field['name'] . '[' . $x . '][thumb]' . $this->field['name_suffix'] ) . '"
id="' . esc_attr( $this->field['id'] ) . '-thumb_url_' . esc_attr( $x ) . '"
value="' . esc_attr( $slide['thumb'] ) . '" readonly="readonly" />';
echo '</li>';
echo '<li>';
echo '<a href="javascript:void(0);" class="button deletion redux-slides-remove">' . esc_html__( 'Delete', 'redux-framework' ) . '</a>';
echo '</li>';
echo '</ul>';
echo '</div>';
echo '</fieldset>';
echo '</div>';
++$x;
}
}
if ( 0 === $x ) {
echo '<div class="redux-slides-accordion-group">';
echo '<fieldset class="redux-field" data-id="' . esc_attr( $this->field['id'] ) . '">';
echo '<h3>';
// translators: Content title for new accordion.
echo '<span class="redux-slides-header">' . esc_html( sprintf( __( 'New %s', 'redux-framework' ), esc_attr( $this->field['content_title'] ) ) ) . '</span>';
echo '</h3>';
echo '<div>';
$hide = ' hide';
echo '<div class="screenshot' . esc_attr( $hide ) . '">';
echo '<a class="of-uploaded-image" href="">';
echo '<img class="redux-slides-image" id="image_image_id_' . esc_attr( $x ) . '" src="" alt="placeholder" target="_blank" rel="external" />';
echo '</a>';
echo '</div>';
// Upload controls DIV.
echo '<div class="upload_button_div">';
// If the user has WP3.5+ show upload/remove button.
echo '<span class="button media_upload_button" id="add_' . esc_attr( $x ) . '">' . esc_html__( 'Upload', 'redux-framework' ) . '</span>';
echo '<span class="button remove-image' . esc_attr( $hide ) . '" id="reset_' . esc_attr( $x ) . '" rel="' . esc_attr( $this->parent->args['opt_name'] . '[' . $this->field['id'] ) . '][attachment_id]">' . esc_html__( 'Remove', 'redux-framework' ) . '</span>';
echo '</div>' . "\n";
echo '<ul id="' . esc_attr( $this->field['id'] ) . '-ul" class="redux-slides-list">';
if ( $this->field['show']['title'] ) {
$title_type = 'text';
} else {
$title_type = 'hidden';
}
$placeholder = ( isset( $this->field['placeholder']['title'] ) ) ? esc_attr( $this->field['placeholder']['title'] ) : __( 'Title', 'redux-framework' );
echo '<li>';
echo '<input
type="' . esc_attr( $title_type ) . '"
id="' . esc_attr( $this->field['id'] . '-title_' . $x ) . '"
name="' . esc_attr( $this->field['name'] . '[' . $x . '][title]' . $this->field['name_suffix'] ) . '"
value=""
placeholder="' . esc_attr( $placeholder ) . '"
class="full-text slide-title" />';
echo '</li>';
if ( $this->field['show']['description'] ) {
$placeholder = ( isset( $this->field['placeholder']['description'] ) ) ? esc_attr( $this->field['placeholder']['description'] ) : __( 'Description', 'redux-framework' );
echo '<li>';
echo '<textarea
name="' . esc_attr( $this->field['name'] . '[' . $x . '][description]' . $this->field['name_suffix'] ) . '"
id="' . esc_attr( $this->field['id'] . '-description_' . $x ) . '"
placeholder="' . esc_attr( $placeholder ) . '"
class="large-text"
rows="6"></textarea>';
echo '</li>';
}
$placeholder = ( isset( $this->field['placeholder']['url'] ) ) ? esc_attr( $this->field['placeholder']['url'] ) : __( 'URL', 'redux-framework' );
if ( $this->field['show']['url'] ) {
$url_type = 'text';
} else {
$url_type = 'hidden';
}
echo '<li>';
echo '<input
type="' . esc_attr( $url_type ) . '"
id="' . esc_attr( $this->field['id'] . '-url_' . $x ) . '"
name="' . esc_attr( $this->field['name'] . '[' . $x . '][url]' . $this->field['name_suffix'] ) . '"
value="" class="full-text" placeholder="' . esc_attr( $placeholder ) . '" />';
echo '</li>';
echo '<li>';
echo '<input
type="hidden"
class="slide-sort"
name="' . esc_attr( $this->field['name'] . '[' . $x . '][sort]' . $this->field['name_suffix'] ) . '"
id="' . esc_attr( $this->field['id'] . '-sort_' . $x ) . '"
value="' . esc_attr( $x ) . '" />';
echo '<li>';
echo '<input
type="hidden"
class="upload-id"
name="' . esc_attr( $this->field['name'] . '[' . $x . '][attachment_id]' . $this->field['name_suffix'] ) . '"
id="' . esc_attr( $this->field['id'] . '-image_id_' . $x ) . '"
value="" />';
echo '<input
type="hidden"
class="upload"
name="' . esc_attr( $this->field['name'] . '[' . $x . '][image]' . $this->field['name_suffix'] ) . '"
id="' . esc_attr( $this->field['id'] . '-image_url_' . $x ) . '"
value="" readonly="readonly" />';
echo '<input
type="hidden"
class="upload-height"
name="' . esc_attr( $this->field['name'] . '[' . $x . '][height]' . $this->field['name_suffix'] ) . '"
id="' . esc_attr( $this->field['id'] . '-image_height_' . $x ) . '"
value="" />';
echo '<input
type="hidden"
class="upload-width"
name="' . esc_attr( $this->field['name'] . '[' . $x . '][width]' . $this->field['name_suffix'] ) . '"
id="' . esc_attr( $this->field['id'] . '-image_width_' . $x ) . '"
value="" />';
echo '</li>';
echo '<input
type="hidden"
class="upload-thumbnail"
name="' . esc_attr( $this->field['name'] . '[' . $x . '][thumb]' . $this->field['name_suffix'] ) . '"
id="' . esc_attr( $this->field['id'] . '-thumb_url_' . $x ) . '"
value="" />';
echo '</li>';
echo '<li>';
echo '<a href="javascript:void(0);" class="button deletion redux-slides-remove">' . esc_html__( 'Delete', 'redux-framework' ) . '</a>';
echo '</li>';
echo '</ul>';
echo '</div>';
echo '</fieldset>';
echo '</div>';
}
echo '</div>';
// translators: Content title for accordion.
echo '<a href="javascript:void(0);" class="button redux-slides-add button-primary" rel-id="' . esc_attr( $this->field['id'] ) . '-ul" rel-name="' . esc_attr( $this->field['name'] . '[title][]' . $this->field['name_suffix'] ) . '">' . esc_html( sprintf( __( 'Add %s', 'redux-framework' ), esc_html( $this->field['content_title'] ) ) ) . '</a>';
echo '<br/>';
}
/**
* Enqueue Function.
* If this field requires any scripts, or css define this function and register/enqueue the scripts/css
*
* @since 1.0.0
* @access public
* @return void
*/
public function enqueue() {
if ( function_exists( 'wp_enqueue_media' ) ) {
wp_enqueue_media();
} else {
wp_enqueue_script( 'media-upload' );
}
if ( $this->parent->args['dev_mode'] ) {
wp_enqueue_style( 'redux-field-media' );
wp_enqueue_style(
'redux-field-slides',
Redux_Core::$url . 'inc/fields/slides/redux-slides.css',
array(),
$this->timestamp
);
}
wp_enqueue_script(
'redux-field-media',
Redux_Core::$url . 'assets/js/media/media' . Redux_Functions::is_min() . '.js',
array( 'jquery', 'redux-js' ),
$this->timestamp,
true
);
wp_enqueue_script(
'redux-field-slides',
Redux_Core::$url . 'inc/fields/slides/redux-slides' . Redux_Functions::is_min() . '.js',
array( 'jquery', 'jquery-ui-core', 'jquery-ui-accordion', 'jquery-ui-sortable', 'redux-field-media' ),
$this->timestamp,
true
);
}
}
}
class_alias( 'Redux_Slides', 'ReduxFramework_Slides' );