191 lines
6.4 KiB
PHP
191 lines
6.4 KiB
PHP
<?php
|
||
namespace Elementor;
|
||
|
||
use Elementor\Core\Utils\Hints;
|
||
use Elementor\Modules\DynamicTags\Module as TagsModule;
|
||
|
||
if ( ! defined( 'ABSPATH' ) ) {
|
||
exit; // Exit if accessed directly.
|
||
}
|
||
|
||
/**
|
||
* Elementor gallery control.
|
||
*
|
||
* A base control for creating gallery chooser control. Based on the WordPress
|
||
* media library galleries. Used to select images from the WordPress media library.
|
||
*
|
||
* @since 1.0.0
|
||
*/
|
||
class Control_Gallery extends Base_Data_Control {
|
||
|
||
/**
|
||
* Get gallery control type.
|
||
*
|
||
* Retrieve the control type, in this case `gallery`.
|
||
*
|
||
* @since 1.0.0
|
||
* @access public
|
||
*
|
||
* @return string Control type.
|
||
*/
|
||
public function get_type() {
|
||
return 'gallery';
|
||
}
|
||
|
||
/**
|
||
* Import gallery images.
|
||
*
|
||
* Used to import gallery control files from external sites while importing
|
||
* Elementor template JSON file, and replacing the old data.
|
||
*
|
||
* @since 1.0.0
|
||
* @access public
|
||
*
|
||
* @param array $settings Control settings
|
||
*
|
||
* @return array Control settings.
|
||
*/
|
||
public function on_import( $settings ) {
|
||
foreach ( $settings as &$attachment ) {
|
||
if ( empty( $attachment['url'] ) ) {
|
||
continue;
|
||
}
|
||
|
||
$attachment = Plugin::$instance->templates_manager->get_import_images_instance()->import( $attachment );
|
||
}
|
||
|
||
// Filter out attachments that don't exist
|
||
$settings = array_filter( $settings );
|
||
|
||
return $settings;
|
||
}
|
||
|
||
/**
|
||
* Render gallery control output in the editor.
|
||
*
|
||
* Used to generate the control HTML in the editor using Underscore JS
|
||
* template. The variables for the class are available using `data` JS
|
||
* object.
|
||
*
|
||
* @since 1.0.0
|
||
* @access public
|
||
*/
|
||
public function content_template() {
|
||
?>
|
||
<div class="elementor-control-field">
|
||
<div class="elementor-control-title">{{{ data.label }}}</div>
|
||
<div class="elementor-control-input-wrapper">
|
||
<# if ( data.description ) { #>
|
||
<div class="elementor-control-field-description">{{{ data.description }}}</div>
|
||
<# } #>
|
||
<div class="elementor-control-media__content elementor-control-tag-area">
|
||
<div class="elementor-control-gallery-status elementor-control-dynamic-switcher-wrapper">
|
||
<span class="elementor-control-gallery-status-title"></span>
|
||
<button class="elementor-control-gallery-clear elementor-control-unit-1 tooltip-target" data-tooltip="<?php echo esc_attr__( 'Clear gallery', 'elementor' ); ?>">
|
||
<i class="eicon-trash-o" aria-hidden="true"></i>
|
||
<span class="elementor-screen-only"><?php echo esc_html__( 'Clear gallery', 'elementor' ); ?></span>
|
||
</button>
|
||
</div>
|
||
<div class="elementor-control-gallery-content">
|
||
<div class="elementor-control-gallery-thumbnails" tabindex="0"></div>
|
||
<div class="elementor-control-gallery-edit">
|
||
<span><i class="eicon-pencil" aria-hidden="true"></i></span>
|
||
<span class="elementor-screen-only"><?php echo esc_html__( 'Edit gallery', 'elementor' ); ?></span>
|
||
</div>
|
||
<button class="elementor-button elementor-control-gallery-add tooltip-target" data-tooltip="<?php echo esc_attr__( 'Add Images', 'elementor' ); ?>">
|
||
<i class="eicon-plus-circle" aria-hidden="true"></i>
|
||
<span class="elementor-screen-only"><?php echo esc_html__( 'Add Images', 'elementor' ); ?></span>
|
||
</button>
|
||
</div>
|
||
</div>
|
||
<?php if ( ! Hints::should_display_hint( 'image-optimization-once' ) && ! Hints::should_display_hint( 'image-optimization' ) ) { ?>
|
||
<div class="elementor-control-media__warnings elementor-descriptor" role="alert" style="display: none;">
|
||
<?php
|
||
Hints::get_notice_template( [
|
||
'type' => 'warning',
|
||
'content' => esc_html__( 'Images marked in red don’t contain ALT text - which is necessary for accessibility and SEO.', 'elementor' ),
|
||
'icon' => true,
|
||
] );
|
||
?>
|
||
</div>
|
||
<?php } ?>
|
||
<?php if ( Hints::should_display_hint( 'image-optimization-once' ) || Hints::should_display_hint( 'image-optimization' ) ) :
|
||
$once_dismissed = Hints::is_dismissed( 'image-optimization-once' );
|
||
if ( $once_dismissed ) {
|
||
if ( Hints::is_plugin_installed( 'image-optimization' ) ) {
|
||
$content = sprintf(
|
||
__( 'This image is large and may slow things down. %1$sActivate Image Optimizer%2$s to reduce size without losing quality.', 'elementor' ),
|
||
'<a href="' . Hints::get_plugin_action_url( 'image-optimization' ) . '" target="_blank">',
|
||
'</a>'
|
||
);
|
||
} else {
|
||
$content = sprintf(
|
||
__( 'This image is large and may slow things down. %1$sInstall Image Optimizer%2$s to reduce size without losing quality.', 'elementor' ),
|
||
'<a href="' . Hints::get_plugin_action_url( 'image-optimization' ) . '" target="_blank">',
|
||
'</a>'
|
||
);
|
||
}
|
||
} else {
|
||
$content = sprintf(
|
||
'%1$s <a href="%2$s" target="_blank">%3$s</a>',
|
||
esc_html__( 'Don’t let unoptimized images be the downfall of your site’s performance.', 'elementor' ),
|
||
Hints::get_plugin_action_url( 'image-optimization' ),
|
||
Hints::is_plugin_installed( 'image-optimization' ) ? esc_html__( 'Activate Image Optimizer!', 'elementor' ) : esc_html__( 'Install Image Optimizer!', 'elementor' )
|
||
);
|
||
}
|
||
$dismissible = $once_dismissed ? 'image_optimizer_hint' : 'image-optimization-once';
|
||
?>
|
||
<div class="elementor-control-media__promotions elementor-descriptor" role="alert" style="display: none;">
|
||
<?php
|
||
Hints::get_notice_template( [
|
||
'display' => ! $once_dismissed,
|
||
'type' => $once_dismissed ? 'warning' : 'info',
|
||
'content' => $content,
|
||
'icon' => true,
|
||
'dismissible' => $dismissible,
|
||
] );
|
||
?>
|
||
</div>
|
||
<?php endif; ?>
|
||
</div>
|
||
</div>
|
||
<?php
|
||
}
|
||
|
||
/**
|
||
* Get gallery control default settings.
|
||
*
|
||
* Retrieve the default settings of the gallery control. Used to return the
|
||
* default settings while initializing the gallery control.
|
||
*
|
||
* @since 1.0.0
|
||
* @access protected
|
||
*
|
||
* @return array Control default settings.
|
||
*/
|
||
protected function get_default_settings() {
|
||
return [
|
||
'label_block' => true,
|
||
'dynamic' => [
|
||
'categories' => [ TagsModule::GALLERY_CATEGORY ],
|
||
'returnType' => 'object',
|
||
],
|
||
];
|
||
}
|
||
|
||
/**
|
||
* Get gallery control default values.
|
||
*
|
||
* Retrieve the default value of the gallery control. Used to return the default
|
||
* values while initializing the gallery control.
|
||
*
|
||
* @since 1.0.0
|
||
* @access public
|
||
*
|
||
* @return array Control default value.
|
||
*/
|
||
public function get_default_value() {
|
||
return [];
|
||
}
|
||
}
|