• Olá preciso criar uma busca (por select) para carros , com as opções ( Marca , Modelo , Ano(de) , Ano(até) , Preço (de) , Preço(até), e o botão de buscar..

    Ja fiz de tudo e não consigo criar essa busca , quando eu consegui criar ele não faz o efeito de quando eu seleciono as Marcas ja aparecerem os modelos certos..

    alguém poderia me ajudar?

    eu estou utilizando o Plugin (Search & Filter)

Visualizando 5 respostas - 1 até 5 (de um total de 5)
  • Moderador Leo Baiano

    (@leobaiano)

    A primeira coisa que você precisa verificar é o que cada campo deste é no seu projeto. Por exemplo, você registra a marca do carro em um campo custom field? É uma taxonomy (categoria)?

    Depois que fizer isso você pode tentar duas coisas:

    1 – Cria um campo hidden no formulário da busca indicando que é uma busca por veiculo, depois você vai utilizar a action pre_get_post para alterar o resultado quando for uma busca. Na função de callback da action você verifica se é uma busca e caso sim se está sendo passado o valor do campo hidden que identifica que é uma busca por carros. Feito isso você modifica os argumentos.

    2 – A segunda opção segue a lógica parecida, só que ao invés de utilizar a busca padrão do WordPress você vai criar uma página e apontar o action do form de busca para ela.

    Da uma olhada se esse GIST te ajuda.

    https://gist.github.com/leobaiano/f835b9d9ff387ac2995f

    https://gist.github.com/leobaiano/c7a6748a71e50984e25f

    Criador do tópico degaus

    (@degaus)

    Então leo eu entendi seus códigos , adicionei eles e tudo mais.. só que acho que estou colocando o search de uma maneira errada que não esta puxando os valores

    só aparece o select e nenhum valor dentro

    Moderador Leo Baiano

    (@leobaiano)

    Não entendi. Você quer dizer que o select que está sendo utilizado para filtrar não está mostrando os valores? Se sim, de onde deveriam vir os valores e como você está fazendo para exibir eles no select?

    Prezados preciso de ajuda urgente comprei um plugin no mercado livre que faz busca cidade e estado para o tema classipress este: wp-custom-fields-search que busca preciso fazer uma busca na seguinte tabela do banco de dados : cp_ad_fields e busque nesta tabela com select o banco de dados estado: cp_state e quando selecionar o estado ele só irá gerar as cidades cadastradas naquele estado tem como? fazer uma pesquisa assim na mão?

    ou como obrigar o banco select chamar apenas a cidade relacionada ao mesmo veja este código:

    
    <?php 
    add_action('wp_ajax_nopriv_count_posts', 'count_posts');
    add_action('wp_ajax_count_posts', 'count_posts');
    
    function count_posts() {
    		
    	global $wpdb;	
    	$values = $_POST['val'];
    	$controls = $_POST['ctrl'];
    	
    	for ($i=0;$i<count($controls);$i++)
    		$controls[$i][value] = $values[$i][value];
    	
    	$q = test($controls);
    	//echo $q;
    	$c = $wpdb->get_var($q);
    	echo $c;
    	die();
    }
    
    function test($controls)
    {
    	global $wpdb;
    	
    	// Build the query
    	$select = "SELECT COUNT(*) FROM $wpdb->posts";
    	$join = "";
    	$where = " WHERE 1=1 AND post_type='ad_listing' AND (post_status='publish' OR post_status='private')";
    	
    	for ($i=0;$i<count($controls);$i++)
    	{
    		//
    		$name = $controls[$i][name];
    		$value = $controls[$i][value];
    		$joiner	= $controls[$i][params][joiner];
    		$numeric = $controls[$i][params][numeric];
    		$comp = $controls[$i][params][comparison];
    		$params = $controls[$i][params];
    		$input = $controls[$i][params][input];
    				
    		if (!empty($value))
    		{
    			switch ($joiner)
    			{
    				case "PostDataJoiner":
    					$where.= getPostDataJoinerWhere($comp, $name, $value);
    					break;
    				case "CustomFieldJoiner":
    					$join.= " JOIN $wpdb->postmeta m".$i." ON m".$i.".post_id=id";
    					//$where.= " AND (m".$i.".meta_key='".$name."' AND m".$i.".meta_value".getComp($comp, $name, $value)."')";
    					$where.= getCustomFieldJoinerWhere($name, $value, $i, $comp, $numeric, $params);
    					break;
    				case "CategoryJoiner":
    					$table = 'm'.$i;
    					$rel = 'rel'.$i;
    					$tax = 'tax'.$i;
    					$join.= " JOIN $wpdb->term_relationships $rel ON $rel.object_id=id JOIN $wpdb->term_taxonomy $tax ON $tax.term_taxonomy_id=$rel.term_taxonomy_id JOIN $wpdb->terms $table ON $table.term_id=$tax.term_id AND $tax.taxonomy='ad_cat'";
    					$where.= getCategoryJoinerWhere($name, $value, $i, $comp);
    					break;
    				case "TagJoiner":
    					$table = 'm'.$i;
    					$rel = 'rel'.$i;
    					$tax = 'tax'.$i;
    					$join.= " JOIN $wpdb->term_relationships $rel ON $rel.object_id=id JOIN $wpdb->term_taxonomy $tax ON $tax.term_taxonomy_id=$rel.term_taxonomy_id JOIN $wpdb->terms $table ON $table.term_id=$tax.term_id AND $tax.taxonomy='ad_tag'";
    					$where.= getCategoryJoinerWhere($name, $value, $i, $comp);
    					break;
    				case "PostTypeJoiner":
    					//preg_replace(); 
    					break;
    				default: 
    					break;		
    			}	
    			
    		}// end if
    	}
    	return $select.$join.$where;	  
    }
    
    function getPostDataJoinerWhere($comp, $name,$value)
    {
    	$suggestedFields = array('all'=>'All Fields',
    							 'post_content'=>'Body Text',
    							 'post_title'=>'Title',
    							 'post_author'=>'Author',
    							 'post_date'=>'Date');
    	// similar for checkbox!
    	if ($name = 'all')
    	{
    		$logic = array();
    		foreach($suggestedFields as $name=>$desc)
    		{
    				if($name=='all') continue;
    				$logic[] =  "( ".getComp($comp, $name,$value).") ";
    		}
    		$logic = " AND (".join(" OR ",$logic).")";
    		return $logic;
    		
    	}
    	else
    		return " AND ( ".getComp($comp, $name, $value). ") ";
    }
    
    function getCategoryJoinerWhere($name, $value, $index, $comp)
    {
    	$res ="";
    	
    	if ($value)
    	{
    		$table = 'm'.$index;
    		/* CHECKBOX
    		if ($params[input] == 'CheckBoxField')
    		{
    			
    			   $logic = array();
    			   foreach($params[options] as $name=>$value)
    				{
    					if($name=='all') continue;
    					$logic[] =  "( ".getComp($comp, $name,$value).") ";
    				}
    				$logic = " AND (".join(" OR ",$logic).")";
    				//return $logic;
    		}
    		else*/ 
    		$res.= " AND (".getComp($comp, "$table.name", $value).")";		
    	}
    	return $res;	
    }
    
    function getCustomFieldJoinerWhere($name, $value, $index, $comp, $numeric, $params)
    {
    	$res = "";		
    	$table = 'm'.$index;
    	$field = "$table.meta_value".(isNumeric($params, $numeric, false) ? '*1':'');
    	$res = " AND ".getComp($comp, $field, $value);
    	if ($name!='all') 
    		$res = " AND ($table.meta_key='$name' ".$res.") "; 
    	
    	return $res;
    }
    //
    function isNumeric($params, $key, $default=null)
    {
    	if (array_key_exists($numeric, $params)) return $params[$key];
    	return $default;
    	
    }
    
    // COMPARISON FUNCTIONS
    function getComp($comparison, $f, $v)
    {
    	switch ($comparison)
    	{
    		case "EqualComparison": 
    			return getEqualComparison($f, $v);
    			break;
    		case "NotEqualComparison":
    				return getNotEqualComparison($f, $v);
    			break;
    		case "LikeComparison":
    				return getLikeComparison($f, $v);
    			break;
    		case "WordsLikeComparison":
    				return getWordsLikeComparison($f, $v);
    			break;
    		case "LessThanComparison":
    				return getLessThanComparison($f, $v);
    			break;
    		case "MoreThanComparison":
    				return getMoreThanComparison($f, $v);
    			break;
    		case "AtMostComparison":
    				return getAtMostComparison($f, $v);
    			break;
    		case "AtLeastComparison":
    				return getAtLeastComparison($f, $v);
    			break;	
    		case "RangeComparison":
    				return getRangeComparison($f, $v);
    			break;
    		default: break;
    	}
    }
    
    function getEqualComparison($field, $value)
    {
    	return "$field = '$value'";	
    }
    
    function getNotEqualComparison($field, $value)
    {
    	return "$field != '$value'";	
    }
    
    function getLikeComparison($field, $value)
    {
    	return "$field LIKE '%$value%'";
    }
    
    function getWordsLikeComparison($field, $value)
    {
    	$words = explode(" ", $value);
    	$like = array(1);
    	foreach($words as $w)
    		$like[] = getLikeComparison($field, $w);
    		
    	return "(".join(" AND ", $like).")";
    }
    
    function getLessThanComparison($field, $value)
    {
    	return "$field < '$value'";
    }
    
    function getMoreThanComparison($field, $value)
    {
    	return "$field > '$value'";
    }
    function getAtMostComparison($field, $value)
    {
    	return "$field <= '$value'";
    }
    function getAtLeastComparison($field, $value)
    {
    	return "$field >= '$value'";
    }
    
    function getRangeComparison($field, $value)
    {
    	list($min, $max)= explode("-", $value);
    	$where = 1;
    	if(strlen($min)>0)  $where.= " AND $field >= $min";
    	if(strlen($max)>0)  $where.= " AND $field <= $max";
    	return $where;
    }
    ?>
    
    -----------------------------------------
    
    E ESTE:
    
    -------------
    
    <?php
    /*
     * Copyright 2009 Don Benjamin
     * Licensed under the Apache License, Version 2.0 (the "License"); 
     * you may not use this file except in compliance with the License. 
     * You may obtain a copy of the License at 
     *
     * 	http://www.apache.org/licenses/LICENSE-2.0 
     *
     * Unless required by applicable law or agreed to in writing, software
     * distributed under the License is distributed on an "AS IS" BASIS, 
     * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 
     * See the License for the specific language governing permissions and 
     * limitations under the License.
     */
    
    /*
     *  This library is required for the configurable search plugin.
     *
     *  It could also be used to make static unconfigurable search plugins.
     *
     * Author: Don Benjamin
     * Author URI: http://don-benjamin.co.uk
     * */
    
    $debugMode =false;
    require_once(dirname(__FILE__).'/dynamic_counter.php');
    
    if ( !defined('WP_CONTENT_URL') )
    	define( 'WP_CONTENT_URL', get_option('siteurl') . '/wp-content');
    if ( !defined('WP_CONTENT_DIR') )
    	define( 'WP_CONTENT_DIR', ABSPATH . 'wp-content' );
    	
    class ParameterisedObject {
    	var $params=array();
    	function ParameterisedObject($params=array()){
    		$this->__construct($params);
    	}
    	function __construct($params=array()){
    		$this->setParams($params);
    		if(!is_array($this->params)){
    			foreach(debug_backtrace() as $trace){
    				extract($trace);
    				echo "<li>$file:$line $class.$function</li>";
    			}
    			die("<h1>".get_class($this)."</h1>");
    		}
    	}
    
    	function setParams($params){
    		$this->params=$params;
    	}
    
    	function param($key,$default=null){
    		if(!array_key_exists($key,$this->params)) return $default;
    		return $this->params[$key];
    	}
    }
    class DB_WP_Widget extends ParameterisedObject {
    	function DB_WP_Widget($name,$params=array()){
    		DB_WP_Widget::__construct($name,$params);
    	}
    	function __construct($name,$params=array()){
    		parent::__construct($params);
    		$this->name = $name;
    		$this->id = strtolower(get_class($this));
    		$options = get_option($this->id);
    
    //		register_sidebar_widget($this->name,array(&$this,'renderWidget'));
    		$doesOwnConfig = $this->param('doesOwnConfig',false);
    		$desc = $this->param('description',$this->name);
    		$widget_ops = array('classname' => $this->id, 'description' => __($desc));
    		$control_ops = array('width' => 400, 'height' => 350, 'id_base' => $this->id);
    		$name = $this->name;
    	
    		$id = false;
    		do {
    			if($options)
    			foreach ( array_keys($options) as $o ) {
    				// Old widgets can have null values for some reason
    				if ( !isset($options[$o]['exists']) )
    					continue;
    				$id = "$this->id-".abs($o); // Never never never translate an id
    				wp_register_sidebar_widget($id, $name, array(&$this,'renderWidget'), $widget_ops, array( 'number' => $o ));
    				wp_register_widget_control($id, $name, array(&$this,'configForm'), $control_ops, array( 'number' => $o ));
    			}
    			$options = array( -1=>array('exists'=>1));
    		} while(!$id);
    	}
    
    	function setParams($params){
    		parent::setParams($this->overrideParams($params));
    	}
    
    	function getDefaults(){
    		return array('doesOwnConfig'=>false);
    	}
    	function overrideParams($params){
    		foreach($this->getDefaults() as $k=>$v){
    			if(!array_key_exists($k,$params)) $params[$k] = $v;
    		}
    		return $params;
    	}
    
    	function renderWidget(){
    		echo "<h1>Unconfigured Widget</h1>";
    	}
    
    	function defaultWidgetConfig(){
    		return array('exists'=>'1');
    	}
    	function getConfig($id=null,$key=null){
    		$options = get_option($this->id);
    		if(is_null($id)) return $options;
    		if(!@array_key_exists($id,$options))
    			$id = preg_replace('/^.*-(\d+)$/','\\1',$id);
    		if(is_null($key))
    			return $options[$id];
    		else 
    			return $options[$id][$key];
    	}
    	function configForm($args,$force=false){
    		static $first;
    		global $wp_registered_widgets;
    
    		if ( !is_array($args) )
    			$args = array( 'number' => $args );
    
    		$args = wp_parse_args($args,array('number'=>-1));
    		static $updated = array();
    
    		$options = get_option($this->id);
    
    		if(!$updated[$this->id] && ($_POST['sidebar'] || $force)){
    			$updated[$this->id]=true;
    			$sidebar = (string) $_POST['sidebar'];
    			$default_options=$this->defaultWidgetConfig();
    
    			$sidebars_widgets = wp_get_sidebars_widgets();
    			if ( isset($sidebars_widgets[$sidebar]) )
    				$this_sidebar = $sidebars_widgets[$sidebar];
    			else
    				$this_sidebar = array();
    
    			foreach ( $this_sidebar as $_widget_id ) {
    				$callback = $wp_registered_widgets[$_widget_id]['callback'];
    			       if(is_array($callback) && get_class($callback[0])==get_class($this) && isset($wp_registered_widgets[$_widget_id]['params'][0]['number']) ) {{
    				       $widget_number = $wp_registered_widgets[$_widget_id]['params'][0]['number'];
    			       }
    				if ( !in_array( "$this->id-$widget_number", $_POST['widget-id'] ) ) 
    					unset($options[$widget_number]);
    				}
    			}
    			foreach ((array)$_POST[$this->id] as $widget_number => $posted) {
    				if(!isset($posted['exists']) && isset($options[$widget_number]))continue;
    
    				$widgetOptions = $this->form_processPost($posted,$options[$widget_number]);
    				$options[$widget_number] = $widgetOptions;
    			}
    			update_option($this->id,$options);
    		}
    		global $mycount;
    		if(-1==$args['number']){
    			$args['number']='%i%';
    			$values = $default_options;
    		} else {
    			$values = $options[$args['number']];
    		}
    		$this->form_outputForm($values,$this->id.'['.$args['number'].']');
    	}
    	function form_processPost($post,$old){
    		return array('exists'=>1);
    	}
    	function form_outputForm($old,$pref){
    		$this->form_existsInput($pref);
    	}
    	function form_existsInput($pref){
    		echo "<input type='hidden' name='".$pref."[exists]' value='1'/>";
    	}
    
    	function nameAsId(){
    		return strtolower(str_replace(" ","_",$this->name));
    	}
    }
    
    class DB_Search_Widget extends DB_WP_Widget {
    	var $inputs = array();
    
    	function DB_Search_Widget($name){
    		DB_Search_Widget::__construct($name);
    	}
    	function __construct($name='Custom',$params=array()){
    		$this->loadTranslations();
    		parent::__construct(sprintf(__('%1$s Search','wp-custom-fields-search'),$name),$params);
    		add_filter('posts_join',array(&$this,'join_meta'));
    		add_filter('posts_where',array(&$this,'sql_restrict'));
    		add_filter('posts_groupby', array(&$this,'sql_group'));
    		
    		add_filter('home_template',array(&$this,'rewriteHome'));
    		add_filter('page_template',array(&$this,'rewriteHome'));
    		add_filter( 'get_search_query', array(&$this,'getSearchDescription'));
    		add_action('wp_head', array(&$this,'outputStylesheets'), 1);
    		
    	}
    	function loadTranslations(){
    		static $loaded;
    		if ( !$loaded && function_exists('load_plugin_textdomain') ) {
    			$loaded=true;
    			if ( !defined('WP_PLUGIN_DIR') ) {
    				load_plugin_textdomain('wp-custom-fields-search', str_replace( ABSPATH, '', dirname(__FILE__) ) );
    			} else {
    				load_plugin_textdomain('wp-custom-fields-search', false, dirname( plugin_basename(__FILE__) ) );
    			}
    		}
    	}
    	function addInput($input){
    		$this->inputs[] = $input;
    	}
    	function outputStylesheets(){
    		$dir = WP_CONTENT_URL .'/plugins/' .  dirname(plugin_basename(__FILE__) ) . '/';
    		echo "\n".'<style type="text/css" media="screen">@import "'. $dir .'templates/searchforms.css";</style>'."\n";
    	}
    
    	function getInputs($params){
    		return $this->inputs;
    	}
    
    	function getTitle(){
    		return $this->param('description',$this->name);
    	}
    
    	function renderWidget($params=array(),$p2 = array()){
    		$title = $this->getTitle($params);
    		$inputs = $this->getInputs($params);
    		$hidden = "<input type='hidden' name='search-class' value='".$this->getPostIdentifier()."'/><input type='hidden' name='widget_number' value='".$p2['number']."'/>";
    		$formCssClass = 'custom_search widget custom_search_'.$this->nameAsId();
    		$formAction = get_option('home');
    		if(function_exists('locate_template'))
    			$formTemplate = locate_template(array('wp-custom-fields-search-form.php'));
    		if(!$formTemplate) $formTemplate = dirname(__FILE__).'/templates/wp-custom-fields-search-form.php';
    
    		foreach($inputs as $k=>$v){
    			if($v->isHidden()){
    				$hidden.=$v->getInput(false);
    				unset($inputs[$k]);
    			}
    		}
    		include($formTemplate);
    	}
    
    	function isPosted(){
    		return $_GET['search-class'] == $this->getPostIdentifier();
    	}
    	function getPostIdentifier(){
    		return get_class($this).'-'.$this->id;
    	}
    	function isHome($isHome){
    		return $isHome && !$this->isPosted();
    	}
    	function rewriteHome($homeTemplate){
    		if($this->isPosted()) return get_query_template('search');
    		return $homeTemplate;
    	}
    
    	function join_meta($join){
    		if($this->isPosted()){
    			$desc = array();
    			foreach($this->getInputs($_REQUEST['widget_number']) as $input){
    				$join = $input->join_meta($join);
    				$desc = $input->describeSearch($desc);
    			}
    			if($desc){
    				$desc = join(__(" e ",'wp-custom-fields-search'),$desc);
    			} else {
    				$desc = __("Todos",'wp-custom-fields-search');
    			}
    			$this->desc=$desc;
    		}
    		return $join;
    	}
    
    	function getSearchDescription($desc){
    		if($this->isPosted()) return $this->desc;
    		return $desc;
    	}
    	function sql_restrict($where){
    		if($this->isPosted()){
    			global $wpdb;
    			/** This could possibly be considered invasive, need to think this bit through
    			 * properly.
    			 */
    			
    			$where = preg_replace("_AND\s*\(ID\s*=\s*'\d+'\)_","",$where);
    			//$where = preg_replace("/AND $wpdb->posts. = '(post|page)'/","",$where);
    			$where = preg_replace("/AND $wpdb->posts.post_type = '(post|page)'/","AND $wpdb->posts.post_type = 'ad_listing'",$where);
    			
    			foreach($this->getInputs($_REQUEST['widget_number']) as $input){
    				$where = $input->sql_restrict($where);
    			}
    		}
    		return $where;
    	}
    	function sql_group($group){	
    		if($this->isPosted()){
    			global $wpdb;
    			$group = "$wpdb->posts.ID";
    		}
    		return $group;
    	}
    	
    	function toSearchString(){
    	}
    }
    
    class SearchFieldBase {
    	function SearchFieldBase(){
    		SearchFieldBase::__construct();
    	}
    	function __construct(){
    		add_filter('search_params',array(&$this,'form_inputs'));
    		static $index;
    		$this->index = ++$index;
    	}
    	function form_inputs($form){
    		die("Unimplemented function ".__CLASS__.".".__FUNCTION__);
    	}
    	function sql_restrict($where){
    		die("Unimplemented function ".__CLASS__.".".__FUNCTION__);
    	}
    }
    
    class Field extends ParameterisedObject {
    	function getValue($name){
    		$v =  $_REQUEST[$this->getHTMLName($name)];
    		if(get_magic_quotes_gpc()) $v= stripslashes($v);
    		return $v;
    	}
    
    	function getHTMLName($name){
    		return 'cs-'.str_replace(" ","_",$name);
    	}
    
    	function getInput($name){
    		$htmlName = $this->getHTMLName($name);
    		$value = $this->getValue($name);
    		return "<input name='$htmlName' value='$value'/>";
    	}
    	function getCSSClass(){
    		return get_class($this);
    	}
    }
    class TextField extends Field {
    }
    class TextInput extends TextField{}
    
    // PATCH: Modify to show categories tree like
    class DropDownField extends Field {
    	function DropDownField($params=array()){
    		$this->__construct($params);
    	}
    	function __construct($params = array()){
    		parent::__construct($params);
    		if($optionString = $this->param('dropdownoptions',false)){
    			$options=array();
    			$optionPairs = explode(',',$optionString);
    			foreach($optionPairs as $option){
    				list($k,$v) = explode(':',$option);
    				if(!$v) $v=$k;
    				$options[$k]=$v;
    			}
    		} else {
    			$options = $this->param('options',array());
    		}
    		$this->options = $options;
    	}
    
    	function getOptions($joiner,$name){
    		if($this->param('fromDb',!$this->options)){
    			$options = array(''=>__('Todos','wp-custom-fields-search'));
    			$auto = $joiner->getAllOptions($name);
    			asort($auto);
    			$options +=$auto;
    			return $options;
    		} else {
    			return $this->options;
    		}
    	}
    	
    	// Check if a cat has parent to build the tree
    	function isSubcat($opt, $joiner)
    	{
    		if (get_class($joiner) == "CategoryJoiner")
    		{		
    			$terms = get_terms('ad_cat');	
    			if ($terms)
    			{	
    				foreach ($terms as $category)
    				{
    					if (($category->name == $opt) && ($category->parent))
    						return true;	
    				}
    			}
    			else return false;
    		}
    		else return false;;
    	}
    	
    	function getInput($name,$joiner,$fieldName=null){
    		if(!$fieldName) $fieldName=$name;
    		$v = $this->getValue($name);
    		$id = $this->getHTMLName($name);
    
    		$options = '';
    		
    		foreach($this->getOptions($joiner,$fieldName) as $option=>$label)
    		{
    					
    				$checked = ($option==$v)?" selected='true'":"";
    				$option = htmlspecialchars($option,ENT_QUOTES);
    				$label = htmlspecialchars($label,ENT_QUOTES);
    				// tree like category
    				if ($this->isSubcat($option, $joiner))
    				{
    					$options.="<option value='$option'$checked>&nbsp;&nbsp;$label</option>";
    				}
    				else{ 
    					$options.="<option value='$option'$checked>$label</option>";
    				}	
    		}	
    		
    		$atts = '';
    		if($this->params['onChange']) $atts = ' onChange="'.htmlspecialchars($this->params['onChange']).'"';
    		if($this->params['id']) $atts .= ' id="'.htmlspecialchars($this->params['id']).'"';
    		if($this->params['css_class']) $atts .= ' class="'.htmlspecialchars($this->params['css_class']).'"';
    		return "<select name='$id'$atts>$options</select>";
    	}
    	
    	/*function getInput($name,$joiner,$fieldName=null){
    		if(!$fieldName) $fieldName=$name;
    		$v = $this->getValue($name);
    		$id = $this->getHTMLName($name);
    
    		$options = '';
    		foreach($this->getOptions($joiner,$fieldName) as $option=>$label){
    			$checked = ($option==$v)?" selected='true'":"";
    			$option = htmlspecialchars($option,ENT_QUOTES);
    			$label = htmlspecialchars($label,ENT_QUOTES);
    			$options.="<option value='$option'$checked>$label</option>";
    		}
    		$atts = '';
    		if($this->params['onChange']) $atts = ' onChange="'.htmlspecialchars($this->params['onChange']).'"';
    		if($this->params['id']) $atts .= ' id="'.htmlspecialchars($this->params['id']).'"';
    		if($this->params['css_class']) $atts .= ' class="'.htmlspecialchars($this->params['css_class']).'"';
    		return "<select name='$id'$atts>$options</select>";
    		//return "<select id='cat' class='searchbar' name='$id'$atts>$options</select>";
    	}*/
    	function getConfigForm($id,$values){
    		return "<label for='$id-dropdown-options'>".__('Drop Down Options','wp-custom-fields-search')."</label><input id='$id-dropdown-options' name='$id"."[dropdownoptions]' value='$values[dropdownoptions]'/>";
    	}
    }
    class HiddenField extends Field {
    	function HiddenField(){
    		$func_args = func_get_args();
    		call_user_func_array(array($this,'__construct'),$func_args);
    	}
    	function __construct($params = array()){
    		$params['hidden']=true;
    		parent::__construct($params);
    	}
    	function getValue(){
    		return $this->param('constant-value',null);
    	}
    
    	function getInput($name){
    		$v=$this->getValue($name);
    		$id = $this->getHTMLName($name);
    		return "<input type='hidden' name='".htmlspecialchars($name)."' value='".htmlspecialchars($v)."'/>";
    	}
    	function getConfigForm($id,$values){
    		return "<label for='$id-constant-value'>".__('Constant Value','wp-custom-fields-search')."</label><input id='$id-constant-value' name='$id"."[constant-value]' value='{$values['constant-value']}'/>";
    	}
    }
    
    /* TODO: Add Caching */
    class CustomFieldReader {
    
    }
    
    // NEW FEATURE: Check Box
    /*
    class CheckBoxField extends Field{
    function CheckBoxField($options=array(),$params=array()){
    		CheckBoxField::__construct($options,$params);
    	}
    	function __construct($params=array()){
    		parent::__construct($params);
    		if($params['checkboxoptions']){
    			$options=array();
    			$optionPairs = explode(',',$params['checkboxoptions']);
    			foreach($optionPairs as $option){
    				list($k,$v) = explode(':',$option);
    				if(!$v) $v=$k;
    				$options[$k]=$v;
    			}
    		}
    		$this->options = $options;
    	}
    	function getOptions($joiner,$name){
    		if($this->param('fromDb',!$this->options)){
    			return $joiner->getAllOptions($name);
    		} else {
    			return $this->options;
    		}
    	}
    	function getInput($name,$joiner,$fieldName=null){
    		if(!$fieldName) $fieldName=$name;
    		$v = $this->getValue($name);
    		$id = $this->getHTMLName($name);
    
    		$options = '';
    		foreach($this->getOptions($joiner,$fieldName) as $option=>$label){
    			$option = htmlspecialchars($option,ENT_QUOTES);
    			$label = htmlspecialchars($label,ENT_QUOTES);
    			$checked = ($option==$v)?" checked='true'":"";
    			$htmlId = "$id-$option";
    
    			$options.="<div class='check-box-wrapper'><input type='checkbox' name='$id' id='$htmlId' value='$option'$checked> <label for='$htmlId'>$label</label></div>";
    		}
    		return $options;
    	}
    	function getCSSClass(){
    		return "CheckBox";
    	}
    	function getConfigForm($id,$values){
    		return "<label for='$id-checkbox-options'>Check Box Options</label><input id='$id-checkbox-options' name='$id"."[checkboxoptions]' value='$values[checkboxoptions]'/>";
    	}
    }
    
    class CheckBoxFromValues extends CheckBoxField {
    	function CheckBoxFromValues($fieldName=null){
    		CheckBoxFromValues::__construct($fieldName);
    	}
    
    	function __construct($fieldName=null,$params){
    		$params['fromDb'] = true;
    		parent::__construct($options,$params);
    	}
    	function getConfigForm($id,$values){
    		return "";
    	}
    }
    */
    class DropDownFromValues extends DropDownField {
    	function DropDownFromValues($params=array()){
    		$this->__construct($params);
    	}
    
    	function __construct($params=array()){
    		$params['fromDb'] = true;
    		parent::__construct(array(),$params);
    	}
    
    	function getConfigForm($id,$values){
    		return "";
    	}
    }
    class RadioButtonField extends Field {
    	function RadioButtonField($options=array(),$params=array()){
    		RadioButtonField::__construct($options,$params);
    	}
    	function __construct($params=array()){
    		parent::__construct($params);
    		if($params['radiobuttonoptions']){
    			$options=array();
    			$optionPairs = explode(',',$params['radiobuttonoptions']);
    			foreach($optionPairs as $option){
    				list($k,$v) = explode(':',$option);
    				if(!$v) $v=$k;
    				$options[$k]=$v;
    			}
    		}
    		$this->options = $options;
    	}
    	function getOptions($joiner,$name){
    		if($this->param('fromDb',!$this->options)){
    			return $joiner->getAllOptions($name);
    		} else {
    			return $this->options;
    		}
    	}
    	function getInput($name,$joiner,$fieldName=null){
    		if(!$fieldName) $fieldName=$name;
    		$v = $this->getValue($name);
    		$id = $this->getHTMLName($name);
    
    		$options = '';
    		foreach($this->getOptions($joiner,$fieldName) as $option=>$label){
    			$option = htmlspecialchars($option,ENT_QUOTES);
    			$label = htmlspecialchars($label,ENT_QUOTES);
    			$checked = ($option==$v)?" checked='true'":"";
    			$htmlId = "$id-$option";
    
    			$options.="<div class='radio-button-wrapper'><input type='radio' name='$id' id='$htmlId' value='$option'$checked> <label for='$htmlId'>$label</label></div>";
    		}
    		return $options;
    	}
    	function getCSSClass(){
    		return "RadioButton";
    	}
    	function getConfigForm($id,$values){
    		return "<label for='$id-radiobutton-options'>Radio Button Options</label><input id='$id-radiobutton-options' name='$id"."[radiobuttonoptions]' value='$values[radiobuttonoptions]'/>";
    	}
    }
    class RadioButtonFromValues extends RadioButtonField {
    	function RadioButtonFromValues($fieldName=null){
    		RadioButtonFromValues::__construct($fieldName);
    	}
    
    	function __construct($fieldName=null,$params){
    		$params['fromDb'] = true;
    		parent::__construct($options,$params);
    	}
    	function getConfigForm($id,$values){
    		return "";
    	}
    }
    
    class Comparison {
    	function addSQLWhere($field,$value){
    		die("Unimplemented function ".__CLASS__.".".__FUNCTION__);
    	}
    	function describeSearch($value){
    		die("Unimplemented function ".__CLASS__.".".__FUNCTION__);
    	}
    }
    class EqualComparison extends Comparison {
    	function addSQLWhere($field,$value){
    		return "$field = '$value'";
    	}
    	function describeSearch($value){
    		return sprintf(__(' =  "%1$s"','wp-custom-fields-search'),$value);
    	}
    }
    class LikeComparison extends Comparison{
    	function addSQLWhere($field,$value){
    		return $this->getLikeString($field,$value);
    	}
    	function getLikeString($field,$value){
    		return "$field LIKE '%$value%'";
    	}
    	function describeSearch($value){
    		return sprintf(__(' contains "%1$s"','wp-custom-fields-search'),$value);
    	}
    }
    
    class WordsLikeComparison extends LikeComparison {
    	function addSQLWhere($field,$value){
    		$words = explode(" ",$value);
    		$like = array(1);
    		foreach($words as $word){
    			$like[] = $this->getLikeString($field,$word);
    		}
    		return "(".join(" AND ",$like).")";
    	}
    	function describeSearch($value){
    		return sprintf(__(' contains "%1$s"','wp-custom-fields-search'),join('"'.__(" and ",'wp-custom-fields-search').'"',explode(" ",$value)));
    	}
    }
    class LessThanComparison extends Comparison{
    	function addSQLWhere($field,$value){
    		return "$field < '$value'";
    	}
    	function describeSearch($value){
    		return sprintf(__(' less than "%1$s"','wp-custom-fields-search'),$value);
    	}
    }
    class AtMostComparison extends Comparison{
    	function addSQLWhere($field,$value){
    		return "$field <= '$value'";
    	}
    	function describeSearch($value){
    		return sprintf(__(' at most "%1$s"','wp-custom-fields-search'),$value);
    	}
    }
    class AtLeastComparison extends Comparison{
    	function addSQLWhere($field,$value){
    		return "$field >= '$value'";
    	}
    	function describeSearch($value){
    		return sprintf(__(' at least "%1$s"','wp-custom-fields-search'),$value);
    	}
    }
    class MoreThanComparison extends Comparison{
    	function addSQLWhere($field,$value){
    		return "$field > '$value'";
    	}
    	function describeSearch($value){
    		return sprintf(__(' more than "%1$s"','wp-custom-fields-search'),$value);
    	}
    }
    class RangeComparison extends Comparison{
    	function addSQLWhere($field,$value){
    		list($min,$max) = explode("-",$value);
    		$where=1;
    		if(strlen($min)>0) $where.=" AND $field >= $min";
    		if(strlen($max)>0) $where.=" AND $field <= $max";
    		return $where;
    	}
    	function describeSearch($value){
    		list($min,$max) = explode("-",$value);
    		if(strlen($min)==0) return sprintf(__(' less than "%1$s"','wp-custom-fields-search'),$max);
    		if(strlen($max)==0) return sprintf(__(' more than "%1$s"','wp-custom-fields-search'),$min);
    		return sprintf(__(' between "%1$s" and "%2$s"','wp-custom-fields-search'),$min,$max);
    	}
    }
    class NotEqualComparison extends Comparison {
    	function addSQLWhere($field,$value){
    		return "$field != '$value'";
    	}
    	function describeSearch($value){
    		return sprintf(__(' is not "%1$s"','wp-custom-fields-search'),$value);
    	}
    }
    
    class BaseJoiner extends ParameterisedObject {
    	function BaseJoiner($name=null,$params=array()){
    		$this->__construct($name,$params);
    	}
    	function __construct($name=null,$params=array()){
    		parent::__construct($params);
    		$this->name=$name;
    	}
    	function sql_join($join,$name,$index,$value){
    		return $join;
    	}
    	function process_where($where){
    		return $where;
    	}
    	function needsField(){
    		return true;
    	}
    }
    class CustomFieldJoiner extends BaseJoiner{
    	function CustomFieldJoiner($name,$params){
    		$this->__construct($name,$params);
    	}
    	function __construct($name,$params){
    		$this->params = $params;
    	}
    	function param($key,$default=null){
    		if(array_key_exists($key,$this->params)) return $this->params[$key];
    		return $default;
    	}
    	function sql_restrict($name,$index,$value,$comparison){
    		$table = 'meta'.$index;
    		$field = "$table.meta_value".($this->param('numeric',false)?'*1':'');
    		$comp = " AND ".$comparison->addSQLWhere($field,$value);
    		if($name!='all')
    			$comp = " AND ( $table.meta_key='$name' ".$comp.") ";
    		return $comp;
    
    	}
    	function sql_join($join,$name,$index,$value){
    		if(!$value && !$this->param('required',false)) return $join;
    		global $wpdb;
    		$table = 'meta'.$index;
    		return "$join JOIN $wpdb->postmeta $table ON $table.post_id=$wpdb->posts.id";
    	}
    	function getAllOptions($fieldName){
    		global $wpdb;
    		$where='';
    		if($fieldName!='all')
    			$where = " WHERE meta_key='$fieldName'";
    		$q = mysql_query($sql = "SELECT DISTINCT meta_value FROM $wpdb->postmeta m JOIN $wpdb->posts p ON m.post_id=p.id AND p.post_status='publish' $where");
    		$options = array();
    		while($r = mysql_fetch_row($q))
    			$options[$r[0]] = $r[0];
    		return $options;
    	}
    	function getSuggestedFields(){
    		global $wpdb;
    		$q = mysql_query($sql = "SELECT DISTINCT meta_key FROM $wpdb->postmeta WHERE meta_key NOT LIKE '\\_%'");
    		$options = array('all'=>'All Fields');
    		while($r = mysql_fetch_row($q))
    			$options[$r[0]] = $r[0];
    		return $options;
    	}
    }
    class CategoryJoiner extends BaseJoiner {
    	function sql_restrict($name,$index,$value,$comparison){
    		if(!($value || $this->params['required'])) return $join;
    		$table = 'meta'.$index;
    		return " AND ( ".$comparison->addSQLWhere("$table.name",$value).")";
    	}
    	function getTaxonomy(){
    		//****** PATCH: WORKING WITH ADS CATEGORIES
    		//return $this->param('taxonomy','category');
    		return $this->param('taxonomy','ad_cat');
    	}
    	function getTaxonomyWhere($table){
    		return "<code>$table</code>.taxonomy='".$this->getTaxonomy()."'";
    	}
    	function sql_join($join,$name,$index,$value){
    		if(!($value || $this->params['required'])) return $join;
    		global $wpdb;
    		$table = 'meta'.$index;
    		$rel = 'rel'.$index;
    		$tax = 'tax'.$index;
    		return $join." JOIN $wpdb->term_relationships $rel ON $rel.object_id=$wpdb->posts.id JOIN  $wpdb->term_taxonomy $tax ON $tax.term_taxonomy_id=$rel.term_taxonomy_id JOIN $wpdb->terms $table ON $table.term_id=$tax.term_id AND ".$this->getTaxonomyWhere($tax);
    	}
    	function getAllOptions($fieldName){
    		global $wpdb;
    		$sql = "SELECT distinct t.name FROM $wpdb->terms AS t INNER JOIN $wpdb->term_taxonomy AS tt ON tt.term_id = t.term_id INNER JOIN $wpdb->term_relationships AS tr ON tr.term_taxonomy_id = tt.term_taxonomy_id JOIN $wpdb->posts p ON tr.object_id=p.id AND p.post_status='publish' WHERE ".$this->getTaxonomyWhere('tt');
    		$q = mysql_query($sql);
    		if($e = mysql_error()) echo "<h1>SQL: $sql</h1>".mysql_error();
    		$options = array();
    		// WORKING ON: Subcategory Tree
    		while($r = mysql_fetch_row($q))
    		{
    			$options[$r[0]] = $r[0];
    		}
    		return $options;
    	}
    	function needsField(){
    		return false;
    	}
    	
    }
    class TagJoiner extends CategoryJoiner {
    	function getTaxonomy(){
    			//PATCH
    			//return $this->param('taxonomy','post_tag');
    			return $this->param('taxonomy','ad_tag');
    	}
    }
    
    class PostTypeJoiner extends BaseJoiner {
    	function process_where($where){
    		global $wpdb;
    		//$where = preg_replace("/AND \($wpdb->posts. *= *'(post|page)'\)/","",$where);
    		// TODO: Check here for PostType search!
    		$where = preg_replace("/AND \($wpdb->posts. *= *'(ad_listing)'\)/","",$where);
    		
    		return $where;
    	}
    	function sql_restrict($name,$index,$value,$comparison){
    		global $wpdb;
    		if(!($value || $this->params['required'])) return $join;
    		return " AND ( ".$comparison->addSQLWhere("$wpdb->posts.",$value).")";
    	}
    	function getAllOptions($fieldName){
    		global $wpdb;
    		$q = mysql_query("SELECT distinct FROM $wpdb->posts p WHERE post_status='publish'") or die(mysql_error());
    		print_r($q);
    		$options = array();
    		while($r = mysql_fetch_row($q))
    			$options[$r[0]] = $r[0];
    		return $options;
    	}
    	function needsField(){
    		return false;
    	}
    }
    
    class PostDataJoiner extends BaseJoiner {
    	function sql_restrict($name,$index,$value,$comparison){
    		global $wpdb;
    		$table = $wpdb->posts;
    		if($name=='all'){
    			$logic = array();
    			foreach($this->getSuggestedFields() as $name=>$desc){
    				if($name=='all') continue;
    				$logic[] =  "( ".$comparison->addSQLWhere("$table.$name",$value).") ";
    			}
    			$logic = " AND (".join(" OR ",$logic).")";
    			return $logic;
    		} else {
    			return " AND ( ".$comparison->addSQLWhere("$table.$name",$value).") ";
    		}
    	}
    	function sql_join($join,$name,$index,$value){
    		return $join;
    	}
    	function getAllOptions($fieldName){
    		
    		global $wpdb;
    		global $post;
    
    		$q = mysql_query("SELECT $fieldName FROM $wpdb->posts");
    		$options = array();
    		$i=0;
    		while($r = mysql_fetch_row($q))
    		{
    			$options[$r[$i]] = $r[$i];
    			$i++;
    		}
    		return $options;
    		
    	}
    	
    	function getSuggestedFields(){
    		return array(
    			'all'=>__('All Fields','wp-custom-fields-search'),
    			'post_content'=>__('Body Text','wp-custom-fields-search'),
    			'post_title'=>__('Title','wp-custom-fields-search'),
    			'post_author'=>__('Author','wp-custom-fields-search'),
    			'post_date'=>__('Date','wp-custom-fields-search'),
    		);
    	}
    }
    
    class CategorySearch {
    }
    
    class CustomSearchField extends SearchFieldBase {
    	function CustomSearchField($nameOrParams,$input=false,$comparison=false,$joiner=false){
    		CustomSearchField::__construct($nameOrParams,$input,$comparison,$joiner);
    	}
    	function __construct($nameOrParams,$input=false,$comparison=false,$joiner=false){
    		parent::__construct();
    		if(!is_array($nameOrParams)){
    			$params = array('name'=>$nameOrParams);
    		} else {
    			$params = $nameOrParams;
    		}
    		$this->name = $params['name'];
    		$this->params = $params;
    
    		$this->joiner = $joiner;
    		$this->comparison = $comparison;
    		$this->input = $input;
    		
    		if(!is_object($this->input)){
    			$input = $this->param('input','TextField');
    			$this->input = new $input($params);
    		}
    		if(!is_object($this->comparison)){
    			$comparison = $this->param('comparison','LikeComparison');
    			$this->comparison = new $comparison();
    		}
    		if(!is_object($this->joiner)){
    			$joiner = $this->param('joiner','CustomFieldJoiner');
    			$this->joiner = new $joiner($this->param('name'),$this->params);
    		}
    
    	}
    	function setIndex($n){
    		$this->index=$n;
    	}
    	function param($key,$default=null){
    		if(array_key_exists($key,$this->params)) return $this->params[$key];
    		return $default;
    	}
    
    	function stripInitialForm($form){
    		$pref='<!--cs-form-->';
    		if(preg_match("/^$pref/",$form)) return $form;
    		else return $pref;
    	}
    
    	function form_inputs($form){
    		$form = $this->stripInitialForm($form);
    		return $form.$this->getInput($this->name,$this->joiner);
    	}
    	function hasValue(){
    		return $this->getValue();
    	}
    	function sql_restrict($where){
    		if($this->hasValue()){
    			$value = $this->getValue();
    			$value = $GLOBALS['wpdb']->escape($value);
    			$where.=$this->joiner->sql_restrict($this->name,$this->index,$value,$this->comparison);
    		}
    		if(method_exists($this->joiner,'process_where'))
    			$where = $this->joiner->process_where($where);
    		return $where;
    	}
    	function describeSearch($current){
    		if($this->hasValue()){
    			$current[] = $this->getLabel()." ".$this->comparison->describeSearch($this->getValue());
    		}
    		return $current;
    
    	}
    	function join_meta($join){
    		global $wpdb;
    		$join=$this->joiner->sql_join($join,$this->name,$this->index,$this->getValue(),$this->comparison);
    		return $join;
    	}
    
    	function getQualifiedName(){
    		// PATCH: Adding cat prefix to identify this kind of control
    		if (get_class($this->joiner) == "CategoryJoiner")
    			return 'cat-'.$this->name.'-'.$this->index;
    		else
    			return $this->name.'-'.$this->index;
    	}
    	function getOldValue(){ return $this->getValue(); }
    	function getValue(){
    		
    		$v = $this->input->getValue($this->getQualifiedName(),$this->name);
    		return $v;
    	}
    	function getLabel(){
    		if(!$this->params['label']) $this->params['label'] = ucwords($this->name);
    		return $this->params['label'];
    	}
    
    	function isHidden(){
    		return $this->input->param('hidden',false);
    	}
    	function getInput($wrap=true){
    		
    		$input = $this->input->getInput($this->getQualifiedName(),$this->joiner,$this->name);
    		if($wrap){
    			$input = "<div class='searchform-param'><label class='searchform-label'>".$this->getLabel()."</label><span class='searchform-input-wrapper'>$input</span></div>";
    		}
    		return $input;
    	}
    	function getCSSClass(){
    		return method_exists($this->input,'getCSSClass')?$this->input->getCSSClass():get_class($this->input);
    	}
    }
    
    function wp_custom_search_fields_include_bridges(){
    	$dir = opendir($path = dirname(__FILE__).'/bridges');
    	while($file = readdir($dir)){
    		if(is_file("$path/$file") && preg_match("/^[^.].*\.php$/",$file)){
    			require_once("$path/$file");
    		}
    	}
    }
    wp_custom_search_fields_include_bridges();
    
    if($debugMode){
    	add_filter('posts_request','debug_dump_query');
    	function debug_dump_query($query){
    		echo "<h1>$query</h1>";
    		
    		return $query;
    	}
    }
    
    ?>
    

    _____________

    SE TIVER COMO FAZER NÃO MÃO ME DÊ UMA DICA PESSOAL URGENTE, OBRIGADO.

    • Esta resposta foi modificada 7 anos, 11 meses atrás por Leo Baiano. Razão: Editado para incluir a tag de código
    Moderador Leo Baiano

    (@leobaiano)

    @nataly-amanda você precisa criar um tópico novo com sua dúvida.

Visualizando 5 respostas - 1 até 5 (de um total de 5)
  • O tópico ‘Busca de carros’ está fechado para novas respostas.