Edit File by line

Deprecated: str_replace(): Passing null to parameter #2 ($replace) of type array|string is deprecated in /home/sportsfever/public_html/filemanger/function.php on line 93

Warning: Undefined array key "page_file_edit_line" in /home/sportsfever/public_html/filemanger/edit_text_line.php on line 32
/home/sportsfe.../httpdocs/clone/wp-conte.../themes/Divi/includes/builder/module/helpers
File: WooCommerceModules.php
* Filters the $outer_wrapper_attrs.
[500] Fix | Delete
* Adds 'data-button-class', 'data-button-icon', 'data-button-icon-tablet' and 'data-button-icon-phone' attributes if needed.
[501] Fix | Delete
*
[502] Fix | Delete
* @since 3.29
[503] Fix | Delete
*
[504] Fix | Delete
* @param array $outer_wrapper_attrs Key value pairs of outer wrapper attributes.
[505] Fix | Delete
* @param ET_Builder_Element $this_class Module's class.
[506] Fix | Delete
*
[507] Fix | Delete
* @return array filtered $outer_wrapper_attrs.
[508] Fix | Delete
*/
[509] Fix | Delete
public static function add_custom_button_icons( $outer_wrapper_attrs, $this_class ) {
[510] Fix | Delete
$custom_icon_values = et_pb_responsive_options()->get_property_values( $this_class->props, 'button_icon' );
[511] Fix | Delete
$custom_icon = isset( $custom_icon_values['desktop'] ) ? $custom_icon_values['desktop'] : '';
[512] Fix | Delete
$custom_icon_tablet = isset( $custom_icon_values['tablet'] ) ? $custom_icon_values['tablet'] : '';
[513] Fix | Delete
$custom_icon_phone = isset( $custom_icon_values['phone'] ) ? $custom_icon_values['phone'] : '';
[514] Fix | Delete
[515] Fix | Delete
if ( '' !== $custom_icon || '' !== $custom_icon_tablet || '' !== $custom_icon_phone ) {
[516] Fix | Delete
$outer_wrapper_attrs['data-button-class'] = esc_attr( $this_class->get_button_classname() );
[517] Fix | Delete
$outer_wrapper_attrs['data-button-icon'] = esc_attr( et_pb_process_font_icon( $custom_icon ) );
[518] Fix | Delete
$outer_wrapper_attrs['data-button-icon-tablet'] = esc_attr( et_pb_process_font_icon( $custom_icon_tablet ) );
[519] Fix | Delete
$outer_wrapper_attrs['data-button-icon-phone'] = esc_attr( et_pb_process_font_icon( $custom_icon_phone ) );
[520] Fix | Delete
}
[521] Fix | Delete
[522] Fix | Delete
return $outer_wrapper_attrs;
[523] Fix | Delete
}
[524] Fix | Delete
[525] Fix | Delete
/**
[526] Fix | Delete
* Gets the columns default.
[527] Fix | Delete
*
[528] Fix | Delete
* @return string
[529] Fix | Delete
*/
[530] Fix | Delete
public static function get_columns_posts_default() {
[531] Fix | Delete
return array(
[532] Fix | Delete
'filter',
[533] Fix | Delete
'et_builder_get_woo_default_columns',
[534] Fix | Delete
);
[535] Fix | Delete
}
[536] Fix | Delete
[537] Fix | Delete
/**
[538] Fix | Delete
* Gets the columns default value for the current Product.
[539] Fix | Delete
*
[540] Fix | Delete
* @return string
[541] Fix | Delete
*/
[542] Fix | Delete
public static function get_columns_posts_default_value() {
[543] Fix | Delete
$post_id = et_core_page_resource_get_the_ID();
[544] Fix | Delete
$post_id = $post_id ? $post_id : (int) et_()->array_get( $_POST, 'current_page.id' );
[545] Fix | Delete
[546] Fix | Delete
$page_layout = get_post_meta( $post_id, '_et_pb_page_layout', true );
[547] Fix | Delete
[548] Fix | Delete
if ( $page_layout && 'et_full_width_page' !== $page_layout && ! ET_Builder_Element::is_theme_builder_layout() ) {
[549] Fix | Delete
return '3'; // Set to 3 if page has sidebar.
[550] Fix | Delete
}
[551] Fix | Delete
[552] Fix | Delete
/*
[553] Fix | Delete
* Default number is based on the WooCommerce plugin default value.
[554] Fix | Delete
*
[555] Fix | Delete
* @see woocommerce_output_related_products()
[556] Fix | Delete
*/
[557] Fix | Delete
return '4';
[558] Fix | Delete
}
[559] Fix | Delete
[560] Fix | Delete
/**
[561] Fix | Delete
* Gets the Title header tag.
[562] Fix | Delete
*
[563] Fix | Delete
* WooCommerce version influences the returned header.
[564] Fix | Delete
*
[565] Fix | Delete
* @return string
[566] Fix | Delete
*/
[567] Fix | Delete
public static function get_title_header() {
[568] Fix | Delete
$header = 'h3';
[569] Fix | Delete
[570] Fix | Delete
if ( ! et_is_woocommerce_plugin_active() ) {
[571] Fix | Delete
return $header;
[572] Fix | Delete
}
[573] Fix | Delete
[574] Fix | Delete
global $woocommerce;
[575] Fix | Delete
if ( version_compare( $woocommerce->version, '3.0.0', '>=' ) ) {
[576] Fix | Delete
$header = 'h2';
[577] Fix | Delete
}
[578] Fix | Delete
[579] Fix | Delete
return $header;
[580] Fix | Delete
}
[581] Fix | Delete
[582] Fix | Delete
/**
[583] Fix | Delete
* Gets the Title selector.
[584] Fix | Delete
*
[585] Fix | Delete
* WooCommerce changed the title tag from h3 to h2 in v3.0.0
[586] Fix | Delete
*
[587] Fix | Delete
* @uses ET_Builder_Module_Helper_Woocommerce_Modules::get_title_header()
[588] Fix | Delete
*
[589] Fix | Delete
* @return string
[590] Fix | Delete
*/
[591] Fix | Delete
public static function get_title_selector() {
[592] Fix | Delete
return sprintf( 'li.product %s', self::get_title_header() );
[593] Fix | Delete
}
[594] Fix | Delete
[595] Fix | Delete
/**
[596] Fix | Delete
* Appends Data Icon attribute to the Outer wrapper.
[597] Fix | Delete
*
[598] Fix | Delete
* @param array $outer_wrapper_attrs Key value pairs of outer wrapper attributes.
[599] Fix | Delete
* @param mixed $this_class Module's class.
[600] Fix | Delete
*
[601] Fix | Delete
* @return array
[602] Fix | Delete
*/
[603] Fix | Delete
public static function output_data_icon_attrs( $outer_wrapper_attrs, $this_class ) {
[604] Fix | Delete
$hover_icon = et_()->array_get( $this_class->props, 'hover_icon', '' );
[605] Fix | Delete
$hover_icon_values = et_pb_responsive_options()->get_property_values( $this_class->props, 'hover_icon' );
[606] Fix | Delete
$hover_icon_tablet = et_()->array_get( $hover_icon_values, 'tablet', '' );
[607] Fix | Delete
$hover_icon_phone = et_()->array_get( $hover_icon_values, 'phone', '' );
[608] Fix | Delete
[609] Fix | Delete
$overlay_attributes = ET_Builder_Module_Helper_Overlay::get_attributes( array(
[610] Fix | Delete
'icon' => $hover_icon,
[611] Fix | Delete
'icon_tablet' => $hover_icon_tablet,
[612] Fix | Delete
'icon_phone' => $hover_icon_phone,
[613] Fix | Delete
) );
[614] Fix | Delete
[615] Fix | Delete
return array_merge( $outer_wrapper_attrs, $overlay_attributes );
[616] Fix | Delete
}
[617] Fix | Delete
[618] Fix | Delete
/**
[619] Fix | Delete
* Return all possible product tabs.
[620] Fix | Delete
* See woocommerce_default_product_tabs() in woocommerce/includes/wc-template-functions.php
[621] Fix | Delete
*
[622] Fix | Delete
* @return array
[623] Fix | Delete
*/
[624] Fix | Delete
public static function get_default_product_tabs() {
[625] Fix | Delete
$tabs = array(
[626] Fix | Delete
'description' => array(
[627] Fix | Delete
'title' => esc_html__( 'Description', 'et_builder' ),
[628] Fix | Delete
'priority' => 10,
[629] Fix | Delete
'callback' => 'woocommerce_product_description_tab',
[630] Fix | Delete
),
[631] Fix | Delete
'additional_information' => array(
[632] Fix | Delete
'title' => esc_html__( 'Additional information', 'et_builder' ),
[633] Fix | Delete
'priority' => 20,
[634] Fix | Delete
'callback' => 'woocommerce_product_additional_information_tab',
[635] Fix | Delete
),
[636] Fix | Delete
'reviews' => array(
[637] Fix | Delete
'title' => esc_html__( 'Reviews', 'et_builder' ),
[638] Fix | Delete
'priority' => 30,
[639] Fix | Delete
'callback' => 'comments_template',
[640] Fix | Delete
),
[641] Fix | Delete
);
[642] Fix | Delete
[643] Fix | Delete
return $tabs;
[644] Fix | Delete
}
[645] Fix | Delete
[646] Fix | Delete
public static function get_default_tab_options() {
[647] Fix | Delete
$tabs = self::get_default_product_tabs();
[648] Fix | Delete
$options = array();
[649] Fix | Delete
[650] Fix | Delete
foreach ( $tabs as $name => $tab ) {
[651] Fix | Delete
if ( ! isset( $tab['title'] ) ) {
[652] Fix | Delete
continue;
[653] Fix | Delete
}
[654] Fix | Delete
[655] Fix | Delete
$options[ $name ] = array(
[656] Fix | Delete
'value' => $name,
[657] Fix | Delete
'label' => 'reviews' === $name ? esc_html__( 'Reviews', 'et_builder' ) :
[658] Fix | Delete
esc_html( $tab['title'] ),
[659] Fix | Delete
);
[660] Fix | Delete
}
[661] Fix | Delete
[662] Fix | Delete
return $options;
[663] Fix | Delete
}
[664] Fix | Delete
[665] Fix | Delete
/**
[666] Fix | Delete
* Get calculated star rating width based on letter spacing value.
[667] Fix | Delete
*
[668] Fix | Delete
* WooCommerce's .star-rating uses `em` based width on float layout;
[669] Fix | Delete
* any additional width caused by letter-spacing makes the calculation incorrect;
[670] Fix | Delete
* thus the `width: calc()` overwrite.
[671] Fix | Delete
*
[672] Fix | Delete
* @param string $value
[673] Fix | Delete
*
[674] Fix | Delete
* @return string
[675] Fix | Delete
*/
[676] Fix | Delete
public static function get_rating_width_style( $value ) {
[677] Fix | Delete
$value = et_builder_process_range_value( $value );
[678] Fix | Delete
$property_value = 'calc(5.4em + (' . $value . ' * 4))';
[679] Fix | Delete
[680] Fix | Delete
return sprintf( 'width: %1$s;', esc_html( $property_value ) );
[681] Fix | Delete
}
[682] Fix | Delete
[683] Fix | Delete
/**
[684] Fix | Delete
* Get margin properties & values based on current alignment status.
[685] Fix | Delete
*
[686] Fix | Delete
* Default star alignment is not controlled by standard text align system. It uses float to control
[687] Fix | Delete
* how stars symbol will be displayed based on the percentage. It's not possible to convert it to
[688] Fix | Delete
* simple text align. We have to use margin left & right to set the alignment.
[689] Fix | Delete
*
[690] Fix | Delete
* @param string $align
[691] Fix | Delete
* @param string $mode
[692] Fix | Delete
*
[693] Fix | Delete
* @return string
[694] Fix | Delete
*/
[695] Fix | Delete
public static function get_rating_alignment_style( $align, $mode = 'desktop' ) {
[696] Fix | Delete
// Bail early if mode is desktop and alignment is left or justify.
[697] Fix | Delete
if ( 'desktop' === $mode && in_array( $align, array( 'left', 'justify' ) ) ) {
[698] Fix | Delete
return array();
[699] Fix | Delete
}
[700] Fix | Delete
[701] Fix | Delete
$margin_properties = array(
[702] Fix | Delete
'center' => array(
[703] Fix | Delete
'left' => 'auto',
[704] Fix | Delete
'right' => 'auto',
[705] Fix | Delete
),
[706] Fix | Delete
'right' => array(
[707] Fix | Delete
'left' => 'auto',
[708] Fix | Delete
'right' => '0',
[709] Fix | Delete
),
[710] Fix | Delete
);
[711] Fix | Delete
[712] Fix | Delete
// By default (left or justify), the margin will be left: inherit and right: auto.
[713] Fix | Delete
$margin_left = et_()->array_get( $margin_properties, "{$align}.left", '0' );
[714] Fix | Delete
$margin_right = et_()->array_get( $margin_properties, "{$align}.right", 'auto' );
[715] Fix | Delete
[716] Fix | Delete
return sprintf(
[717] Fix | Delete
'margin-left: %1$s !important; margin-right: %2$s !important;',
[718] Fix | Delete
esc_html( $margin_left ),
[719] Fix | Delete
esc_html( $margin_right )
[720] Fix | Delete
);
[721] Fix | Delete
}
[722] Fix | Delete
[723] Fix | Delete
/**
[724] Fix | Delete
* Get specific star rating style based on property type.
[725] Fix | Delete
*
[726] Fix | Delete
* @param string $type
[727] Fix | Delete
* @param string $value
[728] Fix | Delete
* @param string $mode
[729] Fix | Delete
*
[730] Fix | Delete
* @return array
[731] Fix | Delete
*/
[732] Fix | Delete
public static function get_rating_style( $type, $value, $mode = 'desktop' ) {
[733] Fix | Delete
$style = array();
[734] Fix | Delete
[735] Fix | Delete
switch ( $type ) {
[736] Fix | Delete
case 'rating_letter_spacing':
[737] Fix | Delete
$style = self::get_rating_width_style( $value );
[738] Fix | Delete
break;
[739] Fix | Delete
case 'rating_text_align':
[740] Fix | Delete
$style = self::get_rating_alignment_style( $value, $mode );
[741] Fix | Delete
break;
[742] Fix | Delete
}
[743] Fix | Delete
[744] Fix | Delete
return $style;
[745] Fix | Delete
}
[746] Fix | Delete
[747] Fix | Delete
/**
[748] Fix | Delete
* Set styles for Woo's .star-rating element.
[749] Fix | Delete
*
[750] Fix | Delete
* @since 3.29
[751] Fix | Delete
*
[752] Fix | Delete
* @param string $render_slug
[753] Fix | Delete
* @param array $attrs
[754] Fix | Delete
* @param string $selector
[755] Fix | Delete
* @param string $hover_selector
[756] Fix | Delete
*
[757] Fix | Delete
* @return void
[758] Fix | Delete
*/
[759] Fix | Delete
public static function add_star_rating_style( $render_slug, $attrs, $selector = '%%order_class%% .star-rating', $hover_selector = '%%order_class%%:hover .star-rating', $props = array() ) {
[760] Fix | Delete
// Supported star rating properties will be handled here.
[761] Fix | Delete
if ( ! is_array( $props ) || empty( $props ) ) {
[762] Fix | Delete
$props = array( 'rating_letter_spacing', 'rating_text_align' );
[763] Fix | Delete
}
[764] Fix | Delete
[765] Fix | Delete
foreach ( $props as $prop ) {
[766] Fix | Delete
// Get raw value.
[767] Fix | Delete
$values = et_pb_responsive_options()->get_property_values( $attrs, $prop );
[768] Fix | Delete
$hover_value = et_pb_hover_options()->get_value( $prop, $attrs, '' );
[769] Fix | Delete
$processed_values = array();
[770] Fix | Delete
[771] Fix | Delete
// Get specific style value for desktop, tablet, and phone.
[772] Fix | Delete
foreach ( $values as $device => $value ) {
[773] Fix | Delete
if ( empty( $value ) ) {
[774] Fix | Delete
continue;
[775] Fix | Delete
}
[776] Fix | Delete
[777] Fix | Delete
$processed_values[ $device ] = self::get_rating_style( $prop, $value, $device );
[778] Fix | Delete
}
[779] Fix | Delete
[780] Fix | Delete
// Generate style for desktop, tablet, and phone.
[781] Fix | Delete
et_pb_responsive_options()->declare_responsive_css(
[782] Fix | Delete
$processed_values,
[783] Fix | Delete
$selector,
[784] Fix | Delete
$render_slug
[785] Fix | Delete
);
[786] Fix | Delete
[787] Fix | Delete
// Generate style for hover.
[788] Fix | Delete
if ( et_builder_is_hover_enabled( $prop, $attrs ) && ! empty( $hover_value ) ) {
[789] Fix | Delete
ET_Builder_Element::set_style( $render_slug, array(
[790] Fix | Delete
'selector' => $hover_selector,
[791] Fix | Delete
'declaration' => self::get_rating_style( $prop, $hover_value, 'hover', true ),
[792] Fix | Delete
) );
[793] Fix | Delete
}
[794] Fix | Delete
}
[795] Fix | Delete
}
[796] Fix | Delete
[797] Fix | Delete
/**
[798] Fix | Delete
* Get the product default.
[799] Fix | Delete
*
[800] Fix | Delete
* @return array
[801] Fix | Delete
*/
[802] Fix | Delete
public static function get_product_default() {
[803] Fix | Delete
return array(
[804] Fix | Delete
'filter',
[805] Fix | Delete
'et_builder_get_woo_default_product',
[806] Fix | Delete
);
[807] Fix | Delete
}
[808] Fix | Delete
[809] Fix | Delete
/**
[810] Fix | Delete
* Get the product default value for the current post type.
[811] Fix | Delete
*
[812] Fix | Delete
* @return string
[813] Fix | Delete
*/
[814] Fix | Delete
public static function get_product_default_value() {
[815] Fix | Delete
$post_id = et_core_page_resource_get_the_ID();
[816] Fix | Delete
$post_id = $post_id ? $post_id : (int) et_()->array_get( $_POST, 'current_page.id' );
[817] Fix | Delete
$post_type = get_post_type( $post_id );
[818] Fix | Delete
[819] Fix | Delete
if ( 'product' === $post_type || et_theme_builder_is_layout_post_type( $post_type ) ) {
[820] Fix | Delete
return 'current';
[821] Fix | Delete
}
[822] Fix | Delete
[823] Fix | Delete
return 'latest';
[824] Fix | Delete
}
[825] Fix | Delete
[826] Fix | Delete
/**
[827] Fix | Delete
* Converts the special chars in to their entities to be used in :before or :after
[828] Fix | Delete
* pseudo selector content.
[829] Fix | Delete
*
[830] Fix | Delete
* @param string $chars
[831] Fix | Delete
*
[832] Fix | Delete
* @since 4.0
[833] Fix | Delete
* @see https://github.com/elegantthemes/Divi/issues/16976
[834] Fix | Delete
*
[835] Fix | Delete
* @return string
[836] Fix | Delete
*/
[837] Fix | Delete
public static function escape_special_chars( $chars ) {
[838] Fix | Delete
switch ( trim( $chars ) ) {
[839] Fix | Delete
case '&':
[840] Fix | Delete
return '\0026';
[841] Fix | Delete
case '>':
[842] Fix | Delete
case '”>”':
[843] Fix | Delete
return '\003e';
[844] Fix | Delete
default:
[845] Fix | Delete
return $chars;
[846] Fix | Delete
}
[847] Fix | Delete
}
[848] Fix | Delete
[849] Fix | Delete
/**
[850] Fix | Delete
* Gets the WooCommerce Tabs defaults.
[851] Fix | Delete
*
[852] Fix | Delete
* Implementation based on
[853] Fix | Delete
*
[854] Fix | Delete
* @see https://github.com/elegantthemes/submodule-builder/pull/6568
[855] Fix | Delete
*
[856] Fix | Delete
* @since 4.4.2
[857] Fix | Delete
*
[858] Fix | Delete
* @return array
[859] Fix | Delete
*/
[860] Fix | Delete
public static function get_woo_default_tabs() {
[861] Fix | Delete
return array(
[862] Fix | Delete
'filter',
[863] Fix | Delete
'et_builder_get_woo_default_tabs',
[864] Fix | Delete
);
[865] Fix | Delete
}
[866] Fix | Delete
[867] Fix | Delete
/**
[868] Fix | Delete
* Gets the WooCommerce Tabs options for the given Product.
[869] Fix | Delete
*
[870] Fix | Delete
* @since 4.4.2
[871] Fix | Delete
*
[872] Fix | Delete
* @return string
[873] Fix | Delete
*/
[874] Fix | Delete
public static function get_woo_default_tabs_options() {
[875] Fix | Delete
$maybe_product_id = self::get_product_default_value();
[876] Fix | Delete
$product_id = self::get_product( $maybe_product_id );
[877] Fix | Delete
[878] Fix | Delete
$current_product = wc_get_product( $product_id );
[879] Fix | Delete
if ( ! $current_product ) {
[880] Fix | Delete
return '';
[881] Fix | Delete
}
[882] Fix | Delete
[883] Fix | Delete
global $product, $post;
[884] Fix | Delete
$original_product = $product;
[885] Fix | Delete
$original_post = $post;
[886] Fix | Delete
$product = $current_product;
[887] Fix | Delete
$post = get_post( $product->get_id() );
[888] Fix | Delete
[889] Fix | Delete
$tabs = apply_filters( 'woocommerce_product_tabs', array() );
[890] Fix | Delete
// Reset global $product.
[891] Fix | Delete
$product = $original_product;
[892] Fix | Delete
$post = $original_post;
[893] Fix | Delete
[894] Fix | Delete
if ( ! empty( $tabs ) ) {
[895] Fix | Delete
return implode( '|', array_keys( $tabs ) );
[896] Fix | Delete
}
[897] Fix | Delete
[898] Fix | Delete
return '';
[899] Fix | Delete
}
[900] Fix | Delete
[901] Fix | Delete
/**
[902] Fix | Delete
* Sets the Display type to render only Products.
[903] Fix | Delete
*
[904] Fix | Delete
* @since 4.1.0
[905] Fix | Delete
*
[906] Fix | Delete
* @see https://github.com/elegantthemes/Divi/issues/17998
[907] Fix | Delete
*
[908] Fix | Delete
* @used-by ET_Builder_Module_Woocommerce_Related_Products::render()
[909] Fix | Delete
* @used-by ET_Builder_Module_Woocommerce_Upsells::render()
[910] Fix | Delete
*
[911] Fix | Delete
* @param string $option_name
[912] Fix | Delete
* @param string $display_type
[913] Fix | Delete
*
[914] Fix | Delete
* @return string
[915] Fix | Delete
*/
[916] Fix | Delete
public static function set_display_type_to_render_only_products( $option_name,
[917] Fix | Delete
$display_type = '' ) {
[918] Fix | Delete
$existing_display_type = get_option( $option_name );
[919] Fix | Delete
update_option( $option_name, $display_type );
[920] Fix | Delete
[921] Fix | Delete
return $existing_display_type;
[922] Fix | Delete
}
[923] Fix | Delete
[924] Fix | Delete
/**
[925] Fix | Delete
* Resets the display type to the existing value.
[926] Fix | Delete
*
[927] Fix | Delete
* @since 4.1.0
[928] Fix | Delete
*
[929] Fix | Delete
* @see https://github.com/elegantthemes/Divi/issues/17998
[930] Fix | Delete
*
[931] Fix | Delete
* @used-by ET_Builder_Module_Woocommerce_Related_Products::render()
[932] Fix | Delete
* @used-by ET_Builder_Module_Woocommerce_Upsells::render()
[933] Fix | Delete
*
[934] Fix | Delete
* @param $option_name
[935] Fix | Delete
* @param $display_type
[936] Fix | Delete
*/
[937] Fix | Delete
public static function reset_display_type( $option_name, $display_type ) {
[938] Fix | Delete
update_option( $option_name, $display_type );
[939] Fix | Delete
}
[940] Fix | Delete
}
[941] Fix | Delete
[942] Fix | Delete
add_filter(
[943] Fix | Delete
'et_builder_get_woo_default_columns',
[944] Fix | Delete
array(
[945] Fix | Delete
'ET_Builder_Module_Helper_Woocommerce_Modules',
[946] Fix | Delete
'get_columns_posts_default_value',
[947] Fix | Delete
)
[948] Fix | Delete
);
[949] Fix | Delete
[950] Fix | Delete
add_filter(
[951] Fix | Delete
'et_builder_get_woo_default_product',
[952] Fix | Delete
array(
[953] Fix | Delete
'ET_Builder_Module_Helper_Woocommerce_Modules',
[954] Fix | Delete
'get_product_default_value',
[955] Fix | Delete
)
[956] Fix | Delete
);
[957] Fix | Delete
[958] Fix | Delete
add_filter(
[959] Fix | Delete
'et_builder_get_woo_default_tabs',
[960] Fix | Delete
array(
[961] Fix | Delete
'ET_Builder_Module_Helper_Woocommerce_Modules',
[962] Fix | Delete
'get_woo_default_tabs_options',
[963] Fix | Delete
)
[964] Fix | Delete
);
[965] Fix | Delete
}
[966] Fix | Delete
[967] Fix | Delete
12
It is recommended that you Edit text format, this type of Fix handles quite a lot in one request
Function