You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
237 lines
6.5 KiB
PHTML
237 lines
6.5 KiB
PHTML
8 months ago
|
<?php
|
||
|
|
||
|
class ET_Builder_Module_Tabs_Item extends ET_Builder_Module {
|
||
|
function init() {
|
||
|
$this->name = esc_html__( 'Tab', 'et_builder' );
|
||
|
$this->plural = esc_html__( 'Tabs', 'et_builder' );
|
||
|
$this->slug = 'et_pb_tab';
|
||
|
$this->vb_support = 'on';
|
||
|
$this->type = 'child';
|
||
|
$this->child_title_var = 'title';
|
||
|
$this->advanced_setting_title_text = esc_html__( 'New Tab', 'et_builder' );
|
||
|
$this->settings_text = esc_html__( 'Tab Settings', 'et_builder' );
|
||
|
$this->main_css_element = '%%order_class%%';
|
||
|
|
||
|
$this->settings_modal_toggles = array(
|
||
|
'general' => array(
|
||
|
'toggles' => array(
|
||
|
'main_content' => et_builder_i18n( 'Text' ),
|
||
|
),
|
||
|
),
|
||
|
);
|
||
|
|
||
|
$this->advanced_fields = array(
|
||
|
'fonts' => array(
|
||
|
'body' => array(
|
||
|
'label' => et_builder_i18n( 'Body' ),
|
||
|
'css' => array(
|
||
|
'main' => ".et_pb_tabs .et_pb_all_tabs {$this->main_css_element}.et_pb_tab",
|
||
|
'line_height' => ".et_pb_tabs {$this->main_css_element}.et_pb_tab p",
|
||
|
'limited_main' => ".et_pb_tabs .et_pb_all_tabs {$this->main_css_element}.et_pb_tab, .et_pb_tabs .et_pb_all_tabs {$this->main_css_element}.et_pb_tab p",
|
||
|
),
|
||
|
'line_height' => array(
|
||
|
'range_settings' => array(
|
||
|
'min' => '1',
|
||
|
'max' => '100',
|
||
|
'step' => '1',
|
||
|
),
|
||
|
),
|
||
|
'block_elements' => array(
|
||
|
'tabbed_subtoggles' => true,
|
||
|
'bb_icons_support' => true,
|
||
|
),
|
||
|
),
|
||
|
'tab' => array(
|
||
|
'label' => esc_html__( 'Tab', 'et_builder' ),
|
||
|
'css' => array(
|
||
|
'main' => ".et_pb_tabs .et_pb_tabs_controls li{$this->main_css_element}, .et_pb_tabs .et_pb_tabs_controls li{$this->main_css_element} a",
|
||
|
'color' => ".et_pb_tabs .et_pb_tabs_controls li{$this->main_css_element} a",
|
||
|
'important' => 'all',
|
||
|
),
|
||
|
'line_height' => array(
|
||
|
'range_settings' => array(
|
||
|
'min' => '1',
|
||
|
'max' => '100',
|
||
|
'step' => '1',
|
||
|
),
|
||
|
),
|
||
|
'hide_text_align' => true,
|
||
|
),
|
||
|
),
|
||
|
'background' => array(
|
||
|
'css' => array(
|
||
|
'main' => ".et_pb_tabs {$this->main_css_element}.et_pb_tab",
|
||
|
),
|
||
|
'settings' => array(
|
||
|
'color' => 'alpha',
|
||
|
),
|
||
|
),
|
||
|
'borders' => array(
|
||
|
'default' => false,
|
||
|
),
|
||
|
'margin_padding' => array(
|
||
|
'use_margin' => false,
|
||
|
'css' => array(
|
||
|
'padding' => '.et_pb_tabs .et_pb_tab%%order_class%%',
|
||
|
),
|
||
|
),
|
||
|
'box_shadow' => array(
|
||
|
'default' => false,
|
||
|
),
|
||
|
'text' => false,
|
||
|
'max_width' => false,
|
||
|
'height' => false,
|
||
|
'button' => false,
|
||
|
'scroll_effects' => false,
|
||
|
'sticky' => false,
|
||
|
);
|
||
|
|
||
|
$this->custom_css_fields = array(
|
||
|
'main_element' => array(
|
||
|
'label' => et_builder_i18n( 'Main Element' ),
|
||
|
'selector' => ".et_pb_tabs div{$this->main_css_element}.et_pb_tab",
|
||
|
),
|
||
|
);
|
||
|
}
|
||
|
|
||
|
function get_fields() {
|
||
|
$fields = array(
|
||
|
'title' => array(
|
||
|
'label' => et_builder_i18n( 'Title' ),
|
||
|
'type' => 'text',
|
||
|
'description' => esc_html__( 'The title will be used within the tab button for this tab.', 'et_builder' ),
|
||
|
'toggle_slug' => 'main_content',
|
||
|
'dynamic_content' => 'text',
|
||
|
'option_category' => 'basic_option',
|
||
|
'mobile_options' => true,
|
||
|
'hover' => 'tabs',
|
||
|
),
|
||
|
'content' => array(
|
||
|
'label' => et_builder_i18n( 'Body' ),
|
||
|
'type' => 'tiny_mce',
|
||
|
'description' => esc_html__( 'Here you can define the content that will be placed within the current tab.', 'et_builder' ),
|
||
|
'toggle_slug' => 'main_content',
|
||
|
'dynamic_content' => 'text',
|
||
|
'option_category' => 'basic_option',
|
||
|
'mobile_options' => true,
|
||
|
'hover' => 'tabs',
|
||
|
),
|
||
|
);
|
||
|
return $fields;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Set the `product` prop on TabItem.
|
||
|
*
|
||
|
* `product` prop is only available w/ the Parents' Tab module and not w/ TabsItem module.
|
||
|
*
|
||
|
* The global $et_pb_wc_tabs variable is set
|
||
|
*/
|
||
|
function maybe_inherit_values() {
|
||
|
// Inheriting Tabs attribute.
|
||
|
global $et_pb_wc_tabs;
|
||
|
|
||
|
if ( isset( $et_pb_wc_tabs ) && ! empty( $et_pb_wc_tabs['product'] ) ) {
|
||
|
$this->props['product'] = $et_pb_wc_tabs['product'];
|
||
|
}
|
||
|
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Return the Product ID when set. Otherwise return parent::get_the_ID()
|
||
|
*
|
||
|
* $this->props['product'] is set using
|
||
|
*
|
||
|
* @see ET_Builder_Module_Tabs_Item->maybe_inherit_values()
|
||
|
*
|
||
|
* @return bool|int
|
||
|
*/
|
||
|
function get_the_ID() {
|
||
|
if ( ! isset( $this->props['product'] ) ) {
|
||
|
return parent::get_the_ID();
|
||
|
}
|
||
|
|
||
|
$product = wc_get_product( absint( $this->props['product'] ) );
|
||
|
if ( $product instanceof WC_Product ) {
|
||
|
return $product->get_id();
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Renders the module output.
|
||
|
*
|
||
|
* @param array $attrs List of attributes.
|
||
|
* @param string $content Content being processed.
|
||
|
* @param string $render_slug Slug of module that is used for rendering output.
|
||
|
*
|
||
|
* @return string
|
||
|
*/
|
||
|
public function render( $attrs, $content, $render_slug ) {
|
||
|
global $et_pb_tab_titles;
|
||
|
global $et_pb_tab_classes;
|
||
|
|
||
|
$multi_view = et_pb_multi_view_options( $this );
|
||
|
|
||
|
$video_background = $this->video_background();
|
||
|
$parallax_image_background = $this->get_parallax_image_background();
|
||
|
|
||
|
$i = 0;
|
||
|
|
||
|
$multi_view->set_default_value( 'title', esc_html__( 'Tab', 'et_builder' ) );
|
||
|
|
||
|
$et_pb_tab_titles[] = $multi_view->get_values( 'title' );
|
||
|
$et_pb_tab_classes[] = ET_Builder_Element::get_module_order_class( $render_slug );
|
||
|
|
||
|
// Module classnames
|
||
|
$this->add_classname(
|
||
|
array(
|
||
|
'clearfix',
|
||
|
$this->get_text_orientation_classname(),
|
||
|
)
|
||
|
);
|
||
|
|
||
|
if ( 1 === count( $et_pb_tab_titles ) ) {
|
||
|
$this->add_classname( 'et_pb_active_content' );
|
||
|
}
|
||
|
|
||
|
// Remove automatically added classnames
|
||
|
$this->remove_classname(
|
||
|
array(
|
||
|
'et_pb_module',
|
||
|
)
|
||
|
);
|
||
|
|
||
|
$content = $multi_view->render_element(
|
||
|
array(
|
||
|
'tag' => 'div',
|
||
|
'content' => '{{content}}',
|
||
|
'attrs' => array(
|
||
|
'class' => 'et_pb_tab_content',
|
||
|
),
|
||
|
)
|
||
|
);
|
||
|
|
||
|
$output = sprintf(
|
||
|
'<div class="%2$s">
|
||
|
%4$s
|
||
|
%3$s
|
||
|
%5$s
|
||
|
%6$s
|
||
|
%1$s
|
||
|
</div>',
|
||
|
$content,
|
||
|
$this->module_classname( $render_slug ),
|
||
|
$video_background,
|
||
|
$parallax_image_background,
|
||
|
et_core_esc_previously( $this->background_pattern() ), // #5
|
||
|
et_core_esc_previously( $this->background_mask() ) // #6
|
||
|
);
|
||
|
|
||
|
return $output;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
if ( et_builder_should_load_all_module_data() ) {
|
||
|
new ET_Builder_Module_Tabs_Item();
|
||
|
}
|