Edit File by line
/home/zeestwma/richards.../wp-conte.../plugins/elemento.../includes/controls
File: select2.php
<?php
[0] Fix | Delete
namespace Elementor;
[1] Fix | Delete
[2] Fix | Delete
if ( ! defined( 'ABSPATH' ) ) {
[3] Fix | Delete
exit; // Exit if accessed directly.
[4] Fix | Delete
}
[5] Fix | Delete
[6] Fix | Delete
/**
[7] Fix | Delete
* Elementor select2 control.
[8] Fix | Delete
*
[9] Fix | Delete
* A base control for creating select2 control. Displays a select box control
[10] Fix | Delete
* based on select2 jQuery plugin @see https://select2.github.io/ .
[11] Fix | Delete
* It accepts an array in which the `key` is the value and the `value` is the
[12] Fix | Delete
* option name. Set `multiple` to `true` to allow multiple value selection.
[13] Fix | Delete
*
[14] Fix | Delete
* @since 1.0.0
[15] Fix | Delete
*/
[16] Fix | Delete
class Control_Select2 extends Base_Data_Control {
[17] Fix | Delete
[18] Fix | Delete
/**
[19] Fix | Delete
* Get select2 control type.
[20] Fix | Delete
*
[21] Fix | Delete
* Retrieve the control type, in this case `select2`.
[22] Fix | Delete
*
[23] Fix | Delete
* @since 1.0.0
[24] Fix | Delete
* @access public
[25] Fix | Delete
*
[26] Fix | Delete
* @return string Control type.
[27] Fix | Delete
*/
[28] Fix | Delete
public function get_type() {
[29] Fix | Delete
return 'select2';
[30] Fix | Delete
}
[31] Fix | Delete
[32] Fix | Delete
/**
[33] Fix | Delete
* Get select2 control default settings.
[34] Fix | Delete
*
[35] Fix | Delete
* Retrieve the default settings of the select2 control. Used to return the
[36] Fix | Delete
* default settings while initializing the select2 control.
[37] Fix | Delete
*
[38] Fix | Delete
* @since 1.8.0
[39] Fix | Delete
* @access protected
[40] Fix | Delete
*
[41] Fix | Delete
* @return array Control default settings.
[42] Fix | Delete
*/
[43] Fix | Delete
protected function get_default_settings() {
[44] Fix | Delete
return [
[45] Fix | Delete
'options' => [],
[46] Fix | Delete
'multiple' => false,
[47] Fix | Delete
// Select2 library options
[48] Fix | Delete
'select2options' => [],
[49] Fix | Delete
// the lockedOptions array can be passed option keys. The passed option keys will be non-deletable.
[50] Fix | Delete
'lockedOptions' => [],
[51] Fix | Delete
];
[52] Fix | Delete
}
[53] Fix | Delete
[54] Fix | Delete
/**
[55] Fix | Delete
* Render select2 control output in the editor.
[56] Fix | Delete
*
[57] Fix | Delete
* Used to generate the control HTML in the editor using Underscore JS
[58] Fix | Delete
* template. The variables for the class are available using `data` JS
[59] Fix | Delete
* object.
[60] Fix | Delete
*
[61] Fix | Delete
* @since 1.0.0
[62] Fix | Delete
* @access public
[63] Fix | Delete
*/
[64] Fix | Delete
public function content_template() {
[65] Fix | Delete
?>
[66] Fix | Delete
<div class="elementor-control-field">
[67] Fix | Delete
<# if ( data.label ) {#>
[68] Fix | Delete
<label for="<?php $this->print_control_uid(); ?>" class="elementor-control-title">{{{ data.label }}}</label>
[69] Fix | Delete
<# } #>
[70] Fix | Delete
<div class="elementor-control-input-wrapper elementor-control-unit-5">
[71] Fix | Delete
<# var multiple = ( data.multiple ) ? 'multiple' : ''; #>
[72] Fix | Delete
<select id="<?php $this->print_control_uid(); ?>" class="elementor-select2" type="select2" {{ multiple }} data-setting="{{ data.name }}">
[73] Fix | Delete
<# _.each( data.options, function( option_title, option_value ) {
[74] Fix | Delete
var value = data.controlValue;
[75] Fix | Delete
if ( typeof value == 'string' ) {
[76] Fix | Delete
var selected = ( option_value === value ) ? 'selected' : '';
[77] Fix | Delete
} else if ( null !== value ) {
[78] Fix | Delete
var value = _.values( value );
[79] Fix | Delete
var selected = ( -1 !== value.indexOf( option_value ) ) ? 'selected' : '';
[80] Fix | Delete
}
[81] Fix | Delete
#>
[82] Fix | Delete
<option {{ selected }} value="{{ _.escape( option_value ) }}">{{{ _.escape( option_title ) }}}</option>
[83] Fix | Delete
<# } ); #>
[84] Fix | Delete
</select>
[85] Fix | Delete
</div>
[86] Fix | Delete
</div>
[87] Fix | Delete
<# if ( data.description ) { #>
[88] Fix | Delete
<div class="elementor-control-field-description">{{{ data.description }}}</div>
[89] Fix | Delete
<# } #>
[90] Fix | Delete
<?php
[91] Fix | Delete
}
[92] Fix | Delete
}
[93] Fix | Delete
[94] Fix | Delete
It is recommended that you Edit text format, this type of Fix handles quite a lot in one request
Function