Edit File by line
/home/zeestwma/richards.../wp-conte.../plugins/elemento.../includes
File: shapes.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 shapes.
[8] Fix | Delete
*
[9] Fix | Delete
* Elementor shapes handler class is responsible for setting up the supported
[10] Fix | Delete
* shape dividers.
[11] Fix | Delete
*
[12] Fix | Delete
* @since 1.3.0
[13] Fix | Delete
*/
[14] Fix | Delete
class Shapes {
[15] Fix | Delete
[16] Fix | Delete
/**
[17] Fix | Delete
* The exclude filter.
[18] Fix | Delete
*/
[19] Fix | Delete
const FILTER_EXCLUDE = 'exclude';
[20] Fix | Delete
[21] Fix | Delete
/**
[22] Fix | Delete
* The include filter.
[23] Fix | Delete
*/
[24] Fix | Delete
const FILTER_INCLUDE = 'include';
[25] Fix | Delete
[26] Fix | Delete
/**
[27] Fix | Delete
* Shapes.
[28] Fix | Delete
*
[29] Fix | Delete
* Holds the list of supported shapes.
[30] Fix | Delete
*
[31] Fix | Delete
* @since 1.3.0
[32] Fix | Delete
* @access private
[33] Fix | Delete
* @static
[34] Fix | Delete
*
[35] Fix | Delete
* @var array A list of supported shapes.
[36] Fix | Delete
*/
[37] Fix | Delete
private static $shapes;
[38] Fix | Delete
[39] Fix | Delete
/**
[40] Fix | Delete
* Get shapes.
[41] Fix | Delete
*
[42] Fix | Delete
* Retrieve a shape from the lists of supported shapes. If no shape specified
[43] Fix | Delete
* it will return all the supported shapes.
[44] Fix | Delete
*
[45] Fix | Delete
* @since 1.3.0
[46] Fix | Delete
* @access public
[47] Fix | Delete
* @static
[48] Fix | Delete
*
[49] Fix | Delete
* @param array $shape Optional. Specific shape. Default is `null`.
[50] Fix | Delete
*
[51] Fix | Delete
* @return array The specified shape or a list of all the supported shapes.
[52] Fix | Delete
*/
[53] Fix | Delete
public static function get_shapes( $shape = null ) {
[54] Fix | Delete
if ( null === self::$shapes ) {
[55] Fix | Delete
self::init_shapes();
[56] Fix | Delete
}
[57] Fix | Delete
[58] Fix | Delete
if ( $shape ) {
[59] Fix | Delete
return isset( self::$shapes[ $shape ] ) ? self::$shapes[ $shape ] : null;
[60] Fix | Delete
}
[61] Fix | Delete
[62] Fix | Delete
return self::$shapes;
[63] Fix | Delete
}
[64] Fix | Delete
[65] Fix | Delete
/**
[66] Fix | Delete
* Filter shapes.
[67] Fix | Delete
*
[68] Fix | Delete
* Retrieve shapes filtered by a specific condition, from the list of
[69] Fix | Delete
* supported shapes.
[70] Fix | Delete
*
[71] Fix | Delete
* @since 1.3.0
[72] Fix | Delete
* @access public
[73] Fix | Delete
* @static
[74] Fix | Delete
*
[75] Fix | Delete
* @param string $by Specific condition to filter by.
[76] Fix | Delete
* @param string $filter Optional. Comparison condition to filter by.
[77] Fix | Delete
* Default is `include`.
[78] Fix | Delete
*
[79] Fix | Delete
* @return array A list of filtered shapes.
[80] Fix | Delete
*/
[81] Fix | Delete
public static function filter_shapes( $by, $filter = self::FILTER_INCLUDE ) {
[82] Fix | Delete
return array_filter(
[83] Fix | Delete
self::get_shapes(), function( $shape ) use ( $by, $filter ) {
[84] Fix | Delete
return self::FILTER_INCLUDE === $filter xor empty( $shape[ $by ] );
[85] Fix | Delete
}
[86] Fix | Delete
);
[87] Fix | Delete
}
[88] Fix | Delete
[89] Fix | Delete
/**
[90] Fix | Delete
* Get shape path.
[91] Fix | Delete
*
[92] Fix | Delete
* For a given shape, retrieve the file path.
[93] Fix | Delete
*
[94] Fix | Delete
* @since 1.3.0
[95] Fix | Delete
* @access public
[96] Fix | Delete
* @static
[97] Fix | Delete
*
[98] Fix | Delete
* @param string $shape The shape.
[99] Fix | Delete
* @param bool $is_negative Optional. Whether the file name is negative or
[100] Fix | Delete
* not. Default is `false`.
[101] Fix | Delete
*
[102] Fix | Delete
* @return string Shape file path.
[103] Fix | Delete
*/
[104] Fix | Delete
public static function get_shape_path( $shape, $is_negative = false ) {
[105] Fix | Delete
if ( ! isset( self::$shapes[ $shape ] ) ) {
[106] Fix | Delete
return '';
[107] Fix | Delete
}
[108] Fix | Delete
[109] Fix | Delete
if ( isset( self::$shapes[ $shape ]['path'] ) ) {
[110] Fix | Delete
$path = self::$shapes[ $shape ]['path'];
[111] Fix | Delete
return ( $is_negative ) ? str_replace( '.svg', '-negative.svg', $path ) : $path;
[112] Fix | Delete
}
[113] Fix | Delete
[114] Fix | Delete
$file_name = $shape;
[115] Fix | Delete
[116] Fix | Delete
if ( $is_negative ) {
[117] Fix | Delete
$file_name .= '-negative';
[118] Fix | Delete
}
[119] Fix | Delete
[120] Fix | Delete
return ELEMENTOR_PATH . 'assets/shapes/' . $file_name . '.svg';
[121] Fix | Delete
}
[122] Fix | Delete
[123] Fix | Delete
/**
[124] Fix | Delete
* Init shapes.
[125] Fix | Delete
*
[126] Fix | Delete
* Set the supported shapes.
[127] Fix | Delete
*
[128] Fix | Delete
* @since 1.3.0
[129] Fix | Delete
* @access private
[130] Fix | Delete
* @static
[131] Fix | Delete
*/
[132] Fix | Delete
private static function init_shapes() {
[133] Fix | Delete
$native_shapes = [
[134] Fix | Delete
'mountains' => [
[135] Fix | Delete
'title' => esc_html_x( 'Mountains', 'Shapes', 'elementor' ),
[136] Fix | Delete
'image' => ELEMENTOR_ASSETS_URL . 'shapes/mountains.svg',
[137] Fix | Delete
'has_flip' => true,
[138] Fix | Delete
],
[139] Fix | Delete
'drops' => [
[140] Fix | Delete
'title' => esc_html_x( 'Drops', 'Shapes', 'elementor' ),
[141] Fix | Delete
'image' => ELEMENTOR_ASSETS_URL . 'shapes/drops.svg',
[142] Fix | Delete
'has_negative' => true,
[143] Fix | Delete
'has_flip' => true,
[144] Fix | Delete
'height_only' => true,
[145] Fix | Delete
],
[146] Fix | Delete
'clouds' => [
[147] Fix | Delete
'title' => esc_html_x( 'Clouds', 'Shapes', 'elementor' ),
[148] Fix | Delete
'image' => ELEMENTOR_ASSETS_URL . 'shapes/clouds.svg',
[149] Fix | Delete
'has_negative' => true,
[150] Fix | Delete
'has_flip' => true,
[151] Fix | Delete
'height_only' => true,
[152] Fix | Delete
],
[153] Fix | Delete
'zigzag' => [
[154] Fix | Delete
'title' => esc_html_x( 'Zigzag', 'Shapes', 'elementor' ),
[155] Fix | Delete
'image' => ELEMENTOR_ASSETS_URL . 'shapes/zigzag.svg',
[156] Fix | Delete
],
[157] Fix | Delete
'pyramids' => [
[158] Fix | Delete
'title' => esc_html_x( 'Pyramids', 'Shapes', 'elementor' ),
[159] Fix | Delete
'image' => ELEMENTOR_ASSETS_URL . 'shapes/pyramids.svg',
[160] Fix | Delete
'has_negative' => true,
[161] Fix | Delete
'has_flip' => true,
[162] Fix | Delete
],
[163] Fix | Delete
'triangle' => [
[164] Fix | Delete
'title' => esc_html_x( 'Triangle', 'Shapes', 'elementor' ),
[165] Fix | Delete
'image' => ELEMENTOR_ASSETS_URL . 'shapes/triangle.svg',
[166] Fix | Delete
'has_negative' => true,
[167] Fix | Delete
],
[168] Fix | Delete
'triangle-asymmetrical' => [
[169] Fix | Delete
'title' => esc_html_x( 'Triangle Asymmetrical', 'Shapes', 'elementor' ),
[170] Fix | Delete
'image' => ELEMENTOR_ASSETS_URL . 'shapes/triangle-asymmetrical.svg',
[171] Fix | Delete
'has_negative' => true,
[172] Fix | Delete
'has_flip' => true,
[173] Fix | Delete
],
[174] Fix | Delete
'tilt' => [
[175] Fix | Delete
'title' => esc_html_x( 'Tilt', 'Shapes', 'elementor' ),
[176] Fix | Delete
'image' => ELEMENTOR_ASSETS_URL . 'shapes/tilt.svg',
[177] Fix | Delete
'has_flip' => true,
[178] Fix | Delete
'height_only' => true,
[179] Fix | Delete
],
[180] Fix | Delete
'opacity-tilt' => [
[181] Fix | Delete
'title' => esc_html_x( 'Tilt Opacity', 'Shapes', 'elementor' ),
[182] Fix | Delete
'image' => ELEMENTOR_ASSETS_URL . 'shapes/opacity-tilt.svg',
[183] Fix | Delete
'has_flip' => true,
[184] Fix | Delete
],
[185] Fix | Delete
'opacity-fan' => [
[186] Fix | Delete
'title' => esc_html_x( 'Fan Opacity', 'Shapes', 'elementor' ),
[187] Fix | Delete
'image' => ELEMENTOR_ASSETS_URL . 'shapes/opacity-fan.svg',
[188] Fix | Delete
],
[189] Fix | Delete
'curve' => [
[190] Fix | Delete
'title' => esc_html_x( 'Curve', 'Shapes', 'elementor' ),
[191] Fix | Delete
'image' => ELEMENTOR_ASSETS_URL . 'shapes/curve.svg',
[192] Fix | Delete
'has_negative' => true,
[193] Fix | Delete
],
[194] Fix | Delete
'curve-asymmetrical' => [
[195] Fix | Delete
'title' => esc_html_x( 'Curve Asymmetrical', 'Shapes', 'elementor' ),
[196] Fix | Delete
'image' => ELEMENTOR_ASSETS_URL . 'shapes/curve-asymmetrical.svg',
[197] Fix | Delete
'has_negative' => true,
[198] Fix | Delete
'has_flip' => true,
[199] Fix | Delete
],
[200] Fix | Delete
'waves' => [
[201] Fix | Delete
'title' => esc_html_x( 'Waves', 'Shapes', 'elementor' ),
[202] Fix | Delete
'image' => ELEMENTOR_ASSETS_URL . 'shapes/waves.svg',
[203] Fix | Delete
'has_negative' => true,
[204] Fix | Delete
'has_flip' => true,
[205] Fix | Delete
],
[206] Fix | Delete
'wave-brush' => [
[207] Fix | Delete
'title' => esc_html_x( 'Waves Brush', 'Shapes', 'elementor' ),
[208] Fix | Delete
'image' => ELEMENTOR_ASSETS_URL . 'shapes/wave-brush.svg',
[209] Fix | Delete
'has_flip' => true,
[210] Fix | Delete
],
[211] Fix | Delete
'waves-pattern' => [
[212] Fix | Delete
'title' => esc_html_x( 'Waves Pattern', 'Shapes', 'elementor' ),
[213] Fix | Delete
'image' => ELEMENTOR_ASSETS_URL . 'shapes/waves-pattern.svg',
[214] Fix | Delete
'has_flip' => true,
[215] Fix | Delete
],
[216] Fix | Delete
'book' => [
[217] Fix | Delete
'title' => esc_html_x( 'Book', 'Shapes', 'elementor' ),
[218] Fix | Delete
'image' => ELEMENTOR_ASSETS_URL . 'shapes/book.svg',
[219] Fix | Delete
'has_negative' => true,
[220] Fix | Delete
],
[221] Fix | Delete
'split' => [
[222] Fix | Delete
'title' => esc_html_x( 'Split', 'Shapes', 'elementor' ),
[223] Fix | Delete
'image' => ELEMENTOR_ASSETS_URL . 'shapes/split.svg',
[224] Fix | Delete
'has_negative' => true,
[225] Fix | Delete
],
[226] Fix | Delete
'arrow' => [
[227] Fix | Delete
'title' => esc_html_x( 'Arrow', 'Shapes', 'elementor' ),
[228] Fix | Delete
'image' => ELEMENTOR_ASSETS_URL . 'shapes/arrow.svg',
[229] Fix | Delete
'has_negative' => true,
[230] Fix | Delete
],
[231] Fix | Delete
];
[232] Fix | Delete
[233] Fix | Delete
self::$shapes = array_merge( $native_shapes, self::get_additional_shapes() );
[234] Fix | Delete
}
[235] Fix | Delete
[236] Fix | Delete
/**
[237] Fix | Delete
* Get Additional Shapes
[238] Fix | Delete
*
[239] Fix | Delete
* Used to add custom shapes to elementor.
[240] Fix | Delete
*
[241] Fix | Delete
* @since 2.5.0
[242] Fix | Delete
*
[243] Fix | Delete
* @return array
[244] Fix | Delete
*/
[245] Fix | Delete
private static function get_additional_shapes() {
[246] Fix | Delete
static $additional_shapes = null;
[247] Fix | Delete
[248] Fix | Delete
if ( null !== $additional_shapes ) {
[249] Fix | Delete
return $additional_shapes;
[250] Fix | Delete
}
[251] Fix | Delete
[252] Fix | Delete
$additional_shapes = [];
[253] Fix | Delete
[254] Fix | Delete
/**
[255] Fix | Delete
* Additional shapes.
[256] Fix | Delete
*
[257] Fix | Delete
* Filters the shapes used by Elementor to add additional shapes.
[258] Fix | Delete
*
[259] Fix | Delete
* @since 2.0.1
[260] Fix | Delete
*
[261] Fix | Delete
* @param array $additional_shapes Additional Elementor shapes.
[262] Fix | Delete
*/
[263] Fix | Delete
$additional_shapes = apply_filters( 'elementor/shapes/additional_shapes', $additional_shapes );
[264] Fix | Delete
[265] Fix | Delete
// BC for addons that add additional shapes the old way using `url` instead of `image`.
[266] Fix | Delete
foreach ( $additional_shapes as $shape_name => $shape_settings ) {
[267] Fix | Delete
if ( ! isset( $shape_settings['image'] ) && isset( $shape_settings['url'] ) ) {
[268] Fix | Delete
$additional_shapes[ $shape_name ]['image'] = $shape_settings['url'];
[269] Fix | Delete
}
[270] Fix | Delete
}
[271] Fix | Delete
[272] Fix | Delete
return $additional_shapes;
[273] Fix | Delete
}
[274] Fix | Delete
[275] Fix | Delete
/**
[276] Fix | Delete
* Get Additional Shapes For Config
[277] Fix | Delete
*
[278] Fix | Delete
* Used to set additional shape paths for editor
[279] Fix | Delete
*
[280] Fix | Delete
* @since 2.5.0
[281] Fix | Delete
*
[282] Fix | Delete
* @return array|bool
[283] Fix | Delete
*/
[284] Fix | Delete
public static function get_additional_shapes_for_config() {
[285] Fix | Delete
$additional_shapes = self::get_additional_shapes();
[286] Fix | Delete
if ( empty( $additional_shapes ) ) {
[287] Fix | Delete
return false;
[288] Fix | Delete
}
[289] Fix | Delete
[290] Fix | Delete
$additional_shapes_config = [];
[291] Fix | Delete
foreach ( $additional_shapes as $shape_name => $shape_settings ) {
[292] Fix | Delete
if ( ! isset( $shape_settings['url'] ) ) {
[293] Fix | Delete
continue;
[294] Fix | Delete
}
[295] Fix | Delete
$additional_shapes_config[ $shape_name ] = $shape_settings['url'];
[296] Fix | Delete
}
[297] Fix | Delete
[298] Fix | Delete
if ( empty( $additional_shapes_config ) ) {
[299] Fix | Delete
return false;
[300] Fix | Delete
}
[301] Fix | Delete
[302] Fix | Delete
return $additional_shapes_config;
[303] Fix | Delete
}
[304] Fix | Delete
}
[305] Fix | Delete
[306] Fix | Delete
It is recommended that you Edit text format, this type of Fix handles quite a lot in one request
Function