SILENT KILLERPanel

Current Path: > home > codekrsu > > ameliagraphics.com > wp-content > plugins > > elementor > includes > controls


Operation   : Linux premium131.web-hosting.com 4.18.0-553.44.1.lve.el8.x86_64 #1 SMP Thu Mar 13 14:29:12 UTC 2025 x86_64
Software     : Apache
Server IP    : 162.0.232.56 | Your IP: 216.73.216.111
Domains      : 1034 Domain(s)
Permission   : [ 0755 ]

Files and Folders in: /home/codekrsu//ameliagraphics.com/wp-content/plugins//elementor/includes/controls

NameTypeSizeLast ModifiedActions
groups Directory - -
alert.php File 1838 bytes January 22 2024 14:24:30.
animation.php File 4870 bytes August 25 2024 17:59:38.
base-data.php File 3750 bytes March 17 2025 17:28:54.
base-icon-font.php File 580 bytes March 17 2025 17:28:54.
base-multiple.php File 2082 bytes March 17 2025 17:28:54.
base-ui.php File 516 bytes April 23 2023 15:22:46.
base-units.php File 3579 bytes February 29 2024 16:51:58.
base.php File 3154 bytes April 23 2023 15:37:02.
box-shadow.php File 3474 bytes April 23 2023 15:22:46.
button.php File 1718 bytes April 23 2023 15:22:46.
choose.php File 2239 bytes June 10 2025 13:36:30.
code.php File 2038 bytes April 23 2023 15:37:02.
color.php File 2084 bytes April 23 2023 15:22:46.
date-time.php File 2085 bytes April 23 2023 15:22:46.
deprecated-notice.php File 2328 bytes April 23 2023 15:22:46.
dimensions.php File 5120 bytes February 18 2025 20:14:26.
divider.php File 829 bytes February 29 2024 16:51:58.
exit-animation.php File 2603 bytes August 25 2024 17:59:38.
font.php File 2269 bytes April 23 2023 15:22:46.
gallery.php File 5825 bytes March 17 2025 17:28:54.
gaps.php File 1657 bytes March 17 2025 17:28:54.
heading.php File 1348 bytes April 23 2023 15:22:46.
hidden.php File 948 bytes April 23 2023 15:22:46.
hover-animation.php File 4425 bytes August 25 2024 17:59:38.
icon.php File 32077 bytes July 09 2023 16:14:12.
icons.php File 7748 bytes June 10 2025 13:36:30.
image-dimensions.php File 3797 bytes April 23 2023 15:22:46.
media.php File 13829 bytes June 10 2025 13:36:30.
notice.php File 4169 bytes December 10 2024 19:19:32.
number.php File 2114 bytes June 10 2025 13:36:30.
popover-toggle.php File 2728 bytes April 23 2023 15:37:02.
raw-html.php File 1519 bytes April 23 2023 15:22:46.
repeater.php File 5083 bytes June 10 2025 13:36:30.
section.php File 1350 bytes July 30 2025 18:59:04.
select.php File 2625 bytes May 28 2023 19:49:54.
select2.php File 2781 bytes November 08 2023 18:47:58.
slider.php File 3572 bytes April 23 2023 15:22:46.
structure.php File 2521 bytes February 29 2024 16:51:58.
switcher.php File 2126 bytes April 23 2023 15:22:46.
tab.php File 1030 bytes February 29 2024 16:51:58.
tabs.php File 944 bytes February 29 2024 16:51:58.
text-shadow.php File 3208 bytes April 23 2023 15:22:46.
text.php File 2130 bytes June 10 2025 13:36:30.
textarea.php File 2054 bytes April 23 2023 15:37:02.
url.php File 5249 bytes June 10 2025 13:36:30.
visual-choice.php File 2204 bytes June 10 2025 13:36:30.
wp-widget.php File 1378 bytes April 23 2023 15:22:46.
wysiwyg.php File 1776 bytes April 23 2023 15:37:02.

Reading File: /home/codekrsu//ameliagraphics.com/wp-content/plugins//elementor/includes/controls/icons.php

<?php
namespace Elementor;

use Elementor\Modules\DynamicTags\Module as TagsModule;

if ( ! defined( 'ABSPATH' ) ) {
	exit; // Exit if accessed directly.
}

/**
 * Elementor Icons control.
 *
 * A base control for creating a Icons chooser control.
 * Used to select an Icon.
 *
 * Usage: @see https://developers.elementor.com/elementor-controls/icons-control
 *
 * @since 2.6.0
 */
class Control_Icons extends Control_Base_Multiple {

	/**
	 * Get media control type.
	 *
	 * Retrieve the control type, in this case `media`.
	 *
	 * @access public
	 * @since 2.6.0
	 * @return string Control type.
	 */
	public function get_type() {
		return 'icons';
	}

	/**
	 * Get Icons control default values.
	 *
	 * Retrieve the default value of the Icons control. Used to return the default
	 * values while initializing the Icons control.
	 *
	 * @access public
	 * @since 2.6.0
	 * @return array Control default value.
	 */
	public function get_default_value() {
		return [
			'value'   => '',
			'library' => '',
		];
	}

	/**
	 * Render Icons 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 2.6.0
	 * @access public
	 */
	public function content_template() {
		?>
		<# if ( 'inline' === data.skin ) { #>
			<?php $this->render_inline_skin(); ?>
		<# } else { #>
			<?php $this->render_media_skin(); ?>
		<# } #>
		<?php
	}

	public function render_media_skin() {
		?>
		<div class="elementor-control-field elementor-control-media">
			<label class="elementor-control-title">{{{ data.label }}}</label>
			<div class="elementor-control-input-wrapper">
				<div class="elementor-control-media__content elementor-control-tag-area elementor-control-preview-area">
					<div class="elementor-control-media-upload-button elementor-control-media__content__upload-button">
						<i class="eicon-plus-circle" aria-hidden="true"></i>
						<span class="elementor-screen-only"><?php echo esc_html__( 'Add', 'elementor' ); ?></span>
					</div>
					<div class="elementor-control-media-area">
						<div class="elementor-control-media__remove elementor-control-media__content__remove" data-tooltip="<?php echo esc_attr__( 'Remove', 'elementor' ); ?>">
							<i class="eicon-trash-o" aria-hidden="true"></i>
							<span class="elementor-screen-only"><?php echo esc_html__( 'Remove', 'elementor' ); ?></span>
						</div>
						<div class="elementor-control-media__preview"></div>
					</div>
					<div class="elementor-control-media__tools elementor-control-dynamic-switcher-wrapper">
						<div class="elementor-control-icon-picker elementor-control-media__tool"><?php echo esc_html__( 'Icon Library', 'elementor' ); ?></div>
						<div class="elementor-control-svg-uploader elementor-control-media__tool"><?php echo esc_html__( 'Upload SVG', 'elementor' ); ?></div>
					</div>
				</div>
			</div>
			<# if ( data.description ) { #>
			<div class="elementor-control-field-description">{{{ data.description }}}</div>
			<# } #>
			<input type="hidden" data-setting="{{ data.name }}"/>
		</div>
		<?php
	}

	public function render_inline_skin() {
		?>
		<#
			const defaultSkinSettings = {
				none: {
					label: '<?php echo esc_html__( 'None', 'elementor' ); ?>',
					icon: 'eicon-ban',
				},
				svg: {
					label: '<?php echo esc_html__( 'Upload SVG', 'elementor' ); ?>',
					icon: 'eicon-upload',
				},
				icon: {
					label: '<?php echo esc_html__( 'Icon Library', 'elementor' ); ?>',
					icon: 'eicon-circle',
				}
			};

			const skinSettings = data.skin_settings.inline;

			const get = ( type, key ) => {
				if ( skinSettings[ type ] ) {
					return skinSettings[ type ]?.[ key ] || defaultSkinSettings[ type ][ key ];
				}

				return defaultSkinSettings[ type ][ key ];
			}
		#>
		<div class="elementor-control-field elementor-control-inline-icon">
			<label class="elementor-control-title">{{{ data.label }}}</label>
			<div class="elementor-control-input-wrapper">
				<div class="elementor-choices">
					<# if ( ! data.exclude_inline_options.includes( 'none' ) ) { #>
						<input id="<?php $this->print_control_uid(); ?>-none" type="radio" value="none">
						<label class="elementor-choices-label elementor-control-unit-1 tooltip-target elementor-control-icons--inline__none" for="<?php $this->print_control_uid(); ?>-none" data-tooltip="{{ get( 'none', 'label' ) }}">
							<i class="{{ get( 'none', 'icon' ) }}" aria-hidden="true"></i>
							<span class="elementor-screen-only">{{ get( 'none', 'label' ) }}</span>
						</label>
					<# }
					if ( ! data.exclude_inline_options.includes( 'svg' ) ) { #>
						<input id="<?php $this->print_control_uid(); ?>-svg" type="radio" value="svg">
						<label class="elementor-choices-label elementor-control-unit-1 tooltip-target elementor-control-icons--inline__svg" for="<?php $this->print_control_uid(); ?>-svg" data-tooltip="{{ get( 'svg', 'label' ) }}">
							<i class="{{ get( 'svg', 'icon' ) }}" aria-hidden="true"></i>
							<span class="elementor-screen-only">{{ get( 'svg', 'label' ) }}</span>
						</label>
					<# }
					if ( ! data.exclude_inline_options.includes( 'icon' ) ) { #>
						<input id="<?php $this->print_control_uid(); ?>-icon" type="radio" value="icon">
						<label class="elementor-choices-label elementor-control-unit-1 tooltip-target elementor-control-icons--inline__icon" for="<?php $this->print_control_uid(); ?>-icon" data-tooltip="{{ get( 'icon', 'label' ) }}">
							<span class="elementor-control-icons--inline__displayed-icon">
								<i class="{{ get( 'icon', 'icon' ) }}" aria-hidden="true"></i>
							</span>
							<span class="elementor-screen-only">{{ get( 'icon', 'label' ) }}</span>
						</label>
					<# } #>
				</div>
			</div>
		</div>

		<# if ( data.description ) { #>
		<div class="elementor-control-field-description">{{{ data.description }}}</div>
		<# } #>
		<?php
	}

	/**
	 * Get Icons control default settings.
	 *
	 * Retrieve the default settings of the Icons control. Used to return the default
	 * settings while initializing the Icons control.
	 *
	 * @since 2.6.0
	 * @access protected
	 *
	 * @return array Control default settings.
	 */
	protected function get_default_settings() {
		return [
			'label_block' => true,
			'dynamic' => [
				'categories' => [ TagsModule::IMAGE_CATEGORY ],
				'returnType' => 'object',
			],
			'search_bar' => true,
			'recommended' => false,
			'skin' => 'media',
			'exclude_inline_options' => [],
			'disable_initial_active_state' => false,
			'skin_settings' => [
				'inline' => [
					'none' => [
						'label' => esc_html__( 'None', 'elementor' ),
						'icon' => 'eicon-ban',
					],
					'svg' => [
						'label' => esc_html__( 'Upload SVG', 'elementor' ),
						'icon' => 'eicon-upload',
					],
					'icon' => [
						'label' => esc_html__( 'Icon Library', 'elementor' ),
						'icon' => 'eicon-circle',
					],
				],
			],
		];
	}

	/**
	 * Support SVG Import
	 *
	 * @param array $mimes
	 * @return array
	 * @deprecated 3.5.0
	 */
	public function support_svg_import( $mimes ) {
		Plugin::$instance->modules_manager->get_modules( 'dev-tools' )->deprecation->deprecated_function( __METHOD__, '3.5.0' );

		$mimes['svg'] = 'image/svg+xml';
		return $mimes;
	}

	public function on_import( $settings ) {
		if ( empty( $settings['library'] ) || 'svg' !== $settings['library'] || empty( $settings['value']['url'] ) ) {
			return $settings;
		}

		$imported = Plugin::$instance->templates_manager->get_import_images_instance()->import( $settings['value'] );

		if ( ! $imported ) {
			$settings['value'] = '';
			$settings['library'] = '';
		} else {
			$settings['value'] = $imported;
		}
		return $settings;
	}
}

SILENT KILLER Tool