Forums Forums Search Search Results for 'sf_input_object_pre function'

Viewing 10 results - 41 through 50 (of 106 total)
  • Author
    Search Results
  • #240014

    In reply to: Selectbox menu


    Trevor
    Participant

    It MIGHT be possible, but only with custom code (I don’t know what this would be though), using this filter:

    https://searchandfilter.com/documentation/action-filter-reference/#filter-input-object

    In code similar to this (in the child theme functions.php file):

    function filter_input_destination($input_object, $sfid)
    {
    	 
    	if(($input_object['name']!='_sft_destination')||($input_object['type']!='select'))
    	{
    		return $input_object;
    	}
    	
    	
    	if(!isset($input_object['options']))
    	{
    		return $input_object;
    	}
    	
    	
    	// sort the array here, using PHP array_multisort() function.
    		
    	return $input_object;
    }
    
    add_filter('sf_input_object_pre', 'filter_input_destination', 10, 2);

    And I would guess make sure it is the correct form ID.

    #236336

    Anonymous
    Inactive

    Thank you again Trevor, although in my case, the value actually does exist in the post data. Perhaps it would help if I gave a more specific example of what I am trying to do ie.

    Option group: Shop, event or both
    Select: Country

    Unfortunately countries are stored as a numerical ID in my postmeta which is why I want to use add_filter to change the label for each of them. For now, the code below attempts to change the label for just one country ie. 13 = Austria.

    Page loads correctly initially and shows all post types for all countries
    If I select one post type plus a country, search results work fine.
    If I select both post types, no results are shown.
    If I try to Reset the form, no results are shown.

    I just cannot understand what the add_filter is doing (or attempting to do) in order to cause such results.

    
    function filter_input_object2($input_object, $sfid)
    {
    	 
    	if(($input_object['name']!='_sfm_country_id')||($input_object['type']!='select'))
    	{
    		return $input_object;
    	}
    	
    	
    	if(!isset($input_object['options']))
    	{
    		return $input_object;
    	}
    	
    	
    	foreach($input_object['options'] as $option)
    	{
    		if($option->value=="13")
    		{
    			$option->label = "Austria";
    		}
    		
    	}
    		
    	return $input_object;
    }
    
    add_filter('sf_input_object_pre', 'filter_input_object2', 10, 2);

    Note: yes I am aware there are ways of entering the postmeta labels manually and it seems that may be my only option but was reluctant to resort to this as it wouldn’t automatically handle new countries as/when they are added.


    Anonymous
    Inactive

    Hi there

    I have search set up which allows the user to search one or both custom post types (ie. shops and events). They can also choose to search by shop category or event category.

    I’m using the code below to add an additional option to the event category select box which works fine IF they select Event as the custom post type to search, however, if they don’t specifically select a custom post type to search (ie. are searching on BOTH types) then no results are returned.

    Note: I’m using shortcodes to create the page ie.

    [searchandfilter id=”13752″]
    [searchandfilter id=”13752″ show=”results”]

    The page loads fine initially, showing all 600 records, but as soon as I run a search without selecting a post type, no results are found… and even clicking “Reset” the query has no effect.

    Any suggestions would be very gratefully received.

    function edit_event_categories($input_object, $sfid) {
    	
    	if(($input_object['name']!='_sft_ecategory')||($input_object['type']!='select'))
    	{
    		return $input_object;
    	}
    	
    	if(!isset($input_object['options']))
    	{
    		return $input_object;
    	}
    	
    	//create a new option we want to add
    	$new_last_option = new StdClass();
    	$new_last_option->value = "99";
    	$new_last_option->label = "Weekend";
    	
    	//add a brand new option to the bottom
    	array_push($input_object['options'], $new_last_option);
    		
    	return $input_object;
    }
    add_filter('sf_input_object_pre', 'edit_event_categories', 10, 2);
    #233286

    Anonymous
    Inactive

    We got it working with this code:

    function my_plugin_search_filter_change_label($input_object, $sfid) {
      if ($sfid == 58513 && $input_object['name'] == '_sf_post_type') {
        foreach ($input_object['options'] as $key => $option) {
          if ($option->label == 'Posts') {
            $input_object['options'][$key]->label = 'Articles';
          } 
        }
      }
      return $input_object;
    }
    add_filter('sf_input_object_pre', 'my_plugin_search_filter_change_label', 10, 2);
    #231607

    In reply to: Range overlap


    Ross
    Keymaster

    Hi Patrick

    It’s not possible within the UI, but you can use a filter to manually update a fields options (and values):
    https://searchandfilter.com/documentation/action-filter-reference/#filter-input-object

    I’ve done a test, and here is the code you would need to affect your mileage field (copy to functions.php in your child theme):

    function update_range_field_mileage($input_object, $sfid)
    {
    	//make sure we affect the '_sfm_mileage' field only
    	if($input_object['name']=='_sfm_mileage')
    	{
    		//udpate this field before rendering
    		//all the options are stored in <code>$input_object['options']</code> as an array
    		$new_options = array();
    		
    		//create a new "default" option
    		$new_option = new StdClass();
    		$new_option->value = "";
    		$new_option->label = "KM Stand";
    		array_push($new_options, $new_option);
    		
    		//create a new range option we want to add
    		$new_option = new StdClass();
    		$new_option->value = "0+49999"; //this is the value that goes in the URL, which affects the query
    		$new_option->label = "0 - 49999"; //the label can be anything
    		array_push($new_options, $new_option);//create a new range option we want to add
    		
    		$new_option = new StdClass();
    		$new_option->value = "50000+99999"; //this is the value that goes in the URL, which affects the query
    		$new_option->label = "50000 - 99999"; //the label can be anything
    		array_push($new_options, $new_option);
    		
    		$new_option = new StdClass();
    		$new_option->value = "100000+150000"; //this is the value that goes in the URL, which affects the query
    		$new_option->label = "100000 - 150000"; //the label can be anything
    		array_push($new_options, $new_option);
    		
    		
    		//now replace the options with our own custom options:
    		$input_object['options'] = $new_options;
    	}
    	
    	return $input_object;
    }
    add_filter('sf_input_object_pre', 'update_range_field_mileage', 10, 2);

    Let me know how you get on.

    Thanks

    #230320

    Ross
    Keymaster

    Hi Holly

    Happy new year to you 🙂

    You should be able to do this using our filter:
    https://searchandfilter.com/documentation/action-filter-reference/#filter-input-object

    This filter will allow you to modify all of the options (as an array) before its processed, this would be the base level code:

    function sf_do_something_with_options($input_object, $sfid){
    
    	//change '_sfm_my_field_name' to the name of your field
    	if($input_object['name']=='_sfm_my_field_name'){
    	
    		//return, if this field doesn't have an options array
    		if(!isset($input_object['options'])){
    			return $input_object;
    		}
    		
    		//to modify the options, we just need to update this array:
    		//$input_object['options'];
    		//so it can be rebuilt however you want, 
    		//use var_dump($input_object['options']) to check the format of the array
    
    	}
    	
    	return $input_object;
    }
    add_filter('sf_input_object_pre', 'sf_do_something_with_options', 10, 2);

    And to see more advanced maniuplation of the options array check:
    https://gist.github.com/rmorse/7b59b45a14b1ca179868

    I hope that helps!

    #230093

    Ross
    Keymaster

    Hi Yanin

    This code should do the trick:

    
    function sf_format_date_labels($input_object, $sfid){
    
    	//change <code>_sfm_date</code> to the name of your field
    	if($input_object['name']=='_sfm_date')
    	{
    		//udpate this field before rendering
    		if(!isset($input_object['options']))
    		{
    			return $input_object;
    		}
    		
    		//now we know there are options we can loop through each one, and change what we need
    		foreach($input_object['options'] as $option)
    		{
    			if($option->value=="")
    			{//the option with no value is always the "all items" or unselected state
    				//$option->label = "This could be a default label";
    			}
    			else
    			{
    				$date = $option->value;
    				
    				//convert date to YYYY-MM-DD so strtototime doesn't mix up months / days
    				$input_date = substr($date, 0, 4) . '-' . substr($date, 4, 2). '-' . substr($date, 6, 2);
    				
    				//now format the date how we want
    				$date_format = "M j, Y";
    				$option->label = date($date_format, strtotime($input_date));
    			}
    		}
    	}
    	
    	return $input_object;
    }
    add_filter('sf_input_object_pre', 'sf_format_date_labels', 10, 2);

    Things to note:
    1) change _sfm_date to the name of your field – you can see the name of your field by checking it in the URL, after performing a search with a date value selected
    2) To change the display format, modify the line:

    
    $date_format = "M j, Y";
    

    You can format the date using the normal PHP date parameters: https://www.php.net/manual/en/function.date.php

    Let me know how you get on.

    Thanks

    #227743

    Anonymous
    Inactive

    I was able to modify the dropdown filter via a hook but it seems that the dropdown filter is not working even without using the hook in the first place.(return no result)
    Do you know why?

    fyi this is the function I used.

    function sf_input_object_pre_mod($input_object,$sfid){
      if($sfid==151){
    if($input_object['name']=='_sfm_property_bedroom'||$input_object['name']=='_sfm_property_bathroom'){
    	  $opts = $input_object['options'];
          foreach($opts as $ok=>$ov){
            $input_object['options'][$ok]->label = preg_replace('/ .+/','',$ov->label);
            $input_object['options'][$ok]->value = preg_replace('/\+.+/','+99',$ov->value);
          }
        }
      }
      return $input_object;
    }
    add_filter('sf_input_object_pre','sf_input_object_pre_mod',10,2);

    Anonymous
    Inactive

    so here is my testing filter:

    function filter_lat_long($input_object, $sfid) {	
    	if(!isset($input_object['options']))
    	{
    		return $input_object;
    	}
    	
    	if(($input_object['name']=='_sfm_location') && ($sfid=='23')) {
    		
    		foreach($input_object['options'] as $option) {
    			
    			$option->value =  'Hello';
    			
    		}
    	}	
    	return $input_object;
    }
    add_filter('sf_input_object_pre', 'filter_lat_long', 10, 2);

    however, $option->value = "Hello"; is not changing the options to “Hello” in the form. what am I missing here?


    Trevor
    Participant

    So, something like this:

    function filter_location($input_object, $sfid)
    {
    	if(($input_object['name']=='_sfm_location') && ($sfid=="23"))
    	{
    		//udpate this field before rendering
    	}
    	
    	return $input_object;
    }
    add_filter('sf_input_object_pre', 'filter_location', 10, 2);
Viewing 10 results - 41 through 50 (of 106 total)