name = esc_html__( 'Search', 'et_builder' ); $this->plural = esc_html__( 'Searches', 'et_builder' ); $this->slug = 'et_pb_search'; $this->vb_support = 'on'; $this->main_css_element = '%%order_class%%'; $this->settings_modal_toggles = array( 'general' => array( 'toggles' => array( 'main_content' => esc_html__( 'Text', 'et_builder' ), 'elements' => esc_html__( 'Elements', 'et_builder' ), 'exceptions' => esc_html__( 'Exceptions', 'et_builder' ), ), ), 'advanced' => array( 'toggles' => array( 'field' => esc_html__( 'Search Field', 'et_builder' ), 'text' => array( 'title' => esc_html__( 'Text', 'et_builder' ), 'priority' => 49, ), 'width' => array( 'title' => esc_html__( 'Sizing', 'et_builder' ), 'priority' => 65, ), ), ), ); $this->advanced_fields = array( 'fonts' => array( 'input' => array( 'label' => esc_html__( 'Input', 'et_builder' ), 'css' => array( 'main' => implode(', ', array( '%%order_class%% form input.et_pb_s', '%%order_class%% form input.et_pb_s::placeholder', '%%order_class%% form input.et_pb_s::-webkit-input-placeholder', '%%order_class%% form input.et_pb_s::-ms-input-placeholder', '%%order_class%% form input.et_pb_s::-moz-placeholder', ) ), 'placeholder' => true, 'important' => array( 'line-height', 'text-shadow' ), ), 'line_height' => array( 'default' => '1em', ), 'font_size' => array( 'default' => '14px', ), 'letter_spacing' => array( 'default' => '0px', ), ), 'button' => array( 'label' => esc_html__( 'Button', 'et_builder' ), 'css' => array( 'main' => "{$this->main_css_element} input.et_pb_searchsubmit", 'important' => array( 'line-height', 'text-shadow' ), ), 'line_height' => array( 'default' => '1em', ), 'font_size' => array( 'default' => '14px', ), 'letter_spacing' => array( 'default' => '0px', ), 'hide_text_align' => true, ), ), 'margin_padding' => array( 'css' => array( 'main' => "{$this->main_css_element} input.et_pb_s", 'important' => 'all', ), ), 'background' => array( 'css' => array( 'main' => "{$this->main_css_element} input.et_pb_s", ), ), 'borders' => array( 'default' => array( 'css' => array( 'main' => array( 'border_radii' => "{$this->main_css_element}.et_pb_search, {$this->main_css_element} input.et_pb_s", 'border_styles' => "{$this->main_css_element}.et_pb_search", ), ), 'defaults' => array( 'border_radii' => 'on|3px|3px|3px|3px', 'border_styles' => array( 'width' => '1px', 'color' => '#dddddd', 'style' => 'solid', ), ), ), ), 'text' => array( 'use_background_layout' => true, 'css' => array( 'main' => "{$this->main_css_element} input.et_pb_searchsubmit, {$this->main_css_element} input.et_pb_s", 'text_shadow' => "{$this->main_css_element} input.et_pb_searchsubmit, {$this->main_css_element} input.et_pb_s", ), 'text_orientation' => array( 'exclude_options' => array( 'justified' ), ), 'options' => array( 'text_orientation' => array( 'default' => 'left', ), 'background_layout' => array( 'default' => 'light', 'hover' => 'tabs', ), ), ), 'button' => false, 'link_options' => false, ); $this->custom_css_fields = array( 'input_field' => array( 'label' => esc_html__( 'Input Field', 'et_builder' ), 'selector' => 'input.et_pb_s', ), 'button' => array( 'label' => esc_html__( 'Button', 'et_builder' ), 'selector' => 'input.et_pb_searchsubmit', ), ); $this->help_videos = array( array( 'id' => esc_html( 'HNmb20Mdvno' ), 'name' => esc_html__( 'An introduction to the Search module', 'et_builder' ), ), ); } function get_fields() { $fields = array( 'exclude_pages' => array( 'label' => esc_html__( 'Exclude Pages', 'et_builder' ), 'type' => 'yes_no_button', 'option_category' => 'configuration', 'options' => array( 'off' => esc_html__( 'No', 'et_builder' ), 'on' => esc_html__( 'Yes', 'et_builder' ), ), 'description' => esc_html__( 'Turning this on will exclude Pages from search results', 'et_builder' ), 'toggle_slug' => 'exceptions', ), 'exclude_posts' => array( 'label' => esc_html__( 'Exclude Posts', 'et_builder' ), 'type' => 'yes_no_button', 'option_category' => 'configuration', 'options' => array( 'off' => esc_html__( 'No', 'et_builder' ), 'on' => esc_html__( 'Yes', 'et_builder' ), ), 'affects' => array( 'include_categories', ), 'description' => esc_html__( 'Turning this on will exclude Posts from search results', 'et_builder' ), 'toggle_slug' => 'exceptions', ), 'include_categories' => array( 'label' => esc_html__( 'Exclude Categories', 'et_builder' ), 'type' => 'categories', 'option_category' => 'basic_option', 'renderer_options' => array( 'use_terms' => false, ), 'depends_show_if' => 'off', 'description' => esc_html__( 'Choose which categories you would like to exclude from the search results.', 'et_builder' ), 'toggle_slug' => 'exceptions', ), 'show_button' => array( 'label' => esc_html__( 'Show Button', 'et_builder' ), 'type' => 'yes_no_button', 'option_category' => 'configuration', 'options' => array( 'on' => esc_html__( 'Yes', 'et_builder' ), 'off' => esc_html__( 'No', 'et_builder' ), ), 'default' => 'on', 'toggle_slug' => 'elements', 'description' => esc_html__( 'Turn this on to show the Search button', 'et_builder' ), ), 'placeholder' => array( 'label' => esc_html__( 'Placeholder Text', 'et_builder' ), 'type' => 'text', 'description' => esc_html__( 'Type the text you want to use as placeholder for the search field.', 'et_builder' ), 'toggle_slug' => 'main_content', 'dynamic_content' => 'text', ), 'button_color' => array( 'label' => esc_html__( 'Button and Border Color', 'et_builder' ), 'type' => 'color-alpha', 'custom_color' => true, 'tab_slug' => 'advanced', 'toggle_slug' => 'button', 'hover' => 'tabs', ), 'placeholder_color' => array( 'label' => esc_html__( 'Placeholder Color', 'et_builder' ), 'type' => 'color-alpha', 'custom_color' => true, 'tab_slug' => 'advanced', 'toggle_slug' => 'field', 'hover' => 'tabs', ), ); return $fields; } public function get_transition_fields_css_props() { $fields = parent::get_transition_fields_css_props(); $fields['placeholder_color'] = array('color' => array( '%%order_class%% form input.et_pb_s::placeholder', '%%order_class%% form input.et_pb_s::-webkit-input-placeholder', '%%order_class%% form input.et_pb_s::-ms-input-placeholder', '%%order_class%% form input.et_pb_s::-moz-placeholder', )); return $fields; } function render( $attrs, $content = null, $render_slug ) { $background_layout = $this->props['background_layout']; $background_layout_hover = et_pb_hover_options()->get_value( 'background_layout', $this->props, 'light' ); $background_layout_hover_enabled = et_pb_hover_options()->is_enabled( 'background_layout', $this->props ); $exclude_categories = $this->props['include_categories']; $exclude_posts = $this->props['exclude_posts']; $exclude_pages = $this->props['exclude_pages']; $button_color = $this->props['button_color']; $button_color_hover = $this->get_hover_value( 'button_color' ); $show_button = $this->props['show_button']; $placeholder = $this->props['placeholder']; $placeholder_color = $this->props['placeholder_color']; $placeholder_color_hover = $this->get_hover_value( 'placeholder_color' ); $input_line_height = $this->props['input_line_height']; $video_background = $this->video_background(); $parallax_image_background = $this->get_parallax_image_background(); $this->content = et_builder_replace_code_content_entities( $this->content ); if ( '' !== $button_color ) { ET_Builder_Element::set_style( $render_slug, array( 'selector' => '%%order_class%% input.et_pb_searchsubmit', 'declaration' => sprintf( 'background: %1$s !important;border-color:%1$s !important;', esc_html( $button_color ) ), ) ); ET_Builder_Element::set_style( $render_slug, array( 'selector' => '%%order_class%% input.et_pb_s', 'declaration' => sprintf( 'border-color:%1$s !important;', esc_html( $button_color ) ), ) ); } if ( et_builder_is_hover_enabled( 'button_color', $this->props ) ) { ET_Builder_Element::set_style( $render_slug, array( 'selector' => '%%order_class%% input.et_pb_searchsubmit:hover', 'declaration' => sprintf( 'background: %1$s !important;border-color:%1$s !important;', esc_html( $button_color_hover ) ), ) ); ET_Builder_Element::set_style( $render_slug, array( 'selector' => '%%order_class%% input.et_pb_s:hover', 'declaration' => sprintf( 'border-color:%1$s !important;', esc_html( $button_color_hover ) ), ) ); } if ( '' !== $placeholder_color ) { $placeholder_selectors = array( '%%order_class%% form input.et_pb_s::-webkit-input-placeholder', '%%order_class%% form input.et_pb_s::-moz-placeholder', '%%order_class%% form input.et_pb_s:-ms-input-placeholder', ); foreach ( $placeholder_selectors as $single_selector ) { ET_Builder_Element::set_style( $render_slug, array( 'selector' => $single_selector, 'declaration' => sprintf( 'color: %1$s !important;', esc_html( $placeholder_color ) ), ) ); } } if ( et_builder_is_hover_enabled( 'placeholder_color', $this->props ) ) { $placeholder_selectors = array( '%%order_class%% form input.et_pb_s:hover::-webkit-input-placeholder', '%%order_class%% form input.et_pb_s:hover::-moz-placeholder', '%%order_class%% form input.et_pb_s:hover:-ms-input-placeholder', ); foreach ( $placeholder_selectors as $single_selector ) { ET_Builder_Element::set_style( $render_slug, array( 'selector' => $single_selector, 'declaration' => sprintf( 'color: %1$s !important;', esc_html( $placeholder_color_hover ) ), ) ); } } if ( '' !== $input_line_height ) { ET_Builder_Element::set_style( $render_slug, array( 'selector' => '%%order_class%% input.et_pb_s', 'declaration' => 'height: auto; min-height: 0;', ) ); } $custom_margin = explode('|', $this->props['custom_margin']); $has_custom_margin = isset( $custom_margin[0], $custom_margin[1], $custom_margin[2], $custom_margin[3] ); $custom_margin_units = array(); if ( $has_custom_margin ) { $button_top = $custom_margin[0]; $button_bottom = $custom_margin[2]; $custom_margin_left_unit = et_pb_get_value_unit( $custom_margin[3] ); $button_right = ( 0 - floatval( $custom_margin[3] ) ) . $custom_margin_left_unit; $custom_margin_units = array( et_pb_get_value_unit( $custom_margin[0] ), et_pb_get_value_unit( $custom_margin[1] ), et_pb_get_value_unit( $custom_margin[2] ), $custom_margin_left_unit, ); ET_Builder_Element::set_style( $render_slug, array( 'selector' => '%%order_class%%.et_pb_search input.et_pb_searchsubmit', 'declaration' => sprintf( 'min-height: 0 !important; top: %1$s; right: %2$s; bottom: %3$s;', esc_html( $button_top ), esc_html( $button_right ), esc_html( $button_bottom ) ), ) ); } // Module classnames $this->add_classname( array( "et_pb_bg_layout_{$background_layout}", $this->get_text_orientation_classname(true), ) ); if ( 'on' !== $show_button ) { $this->add_classname( 'et_pb_hide_search_button' ); } if ( ! empty( $custom_margin_units ) && in_array( '%', $custom_margin_units ) ) { $this->add_classname( 'et_pb_search_percentage_custom_margin' ); } $data_background_layout = ''; $data_background_layout_hover = ''; if ( $background_layout_hover_enabled ) { $data_background_layout = sprintf( ' data-background-layout="%1$s"', esc_attr( $background_layout ) ); $data_background_layout_hover = sprintf( ' data-background-layout-hover="%1$s"', esc_attr( $background_layout_hover ) ); } $output = sprintf( '