• Resolved bigdrop.gr

    (@bigdropgr)


    Hi,

    On a previous support thread I asked you how to change per category the prices.
    https://www.ads-software.com/support/topic/change-price-based-on-category/
    Your solution worked like a charm.

    I would like to know if there is an option to adjust prices by X but if there is a specific value for this category to adjust them by the category value.

    ex. if I have products in “monitors”, “laptops”, “smartphones” and “keyboards”
    and on my function I have specific values for “laptops”, “smartphones” and “keyboards”

    function price_adjust_import( $price, $element ) {
        $price = str_replace( ',', '.', $price );
        $adjust_map = array(
            'laptops' => 1.4,
            'smartphones' => 1.6,
            'keyboards' => 1.5
        );
    
        return ( array_key_exists( $element, $adjust_map ) ) ? ($price * $adjust_map[ $element ] ) : $price;
    }

    Can I have a “global” value that will apply to “monitors” category to the above example?

Viewing 4 replies - 1 through 4 (of 4 total)
  • Plugin Author WP All Import

    (@wpallimport)

    Hi @bigdropgr,

    Can I have a “global” value that will apply to “monitors” category to the above example?

    Sure, you can add a rule named “global” or “default” with the default mark-up, e.g.:

    function price_adjust_import( $price, $element ) {
        $price = str_replace( ',', '.', $price );
        $adjust_map = array(
            'laptops' => 1.4,
            'smartphones' => 1.6,
            'keyboards' => 1.5,
            'default' => 1.3
        );
    
        return ( array_key_exists( $element, $adjust_map ) ) ? ($price * $adjust_map[ $element ] ) : ( $price * $adjust_map['default'] );
    }
    Thread Starter bigdrop.gr

    (@bigdropgr)

    Hi,

    Thank you very much for your reply.
    Can you please help me in a minor change to your code?
    All the prices from the XML must be multiplied by the $adjust_map and then I need to add 3,5 (fixed amount) and then round them up to 2 decimals.
    Is this code ok?

    function price_adjust_import( $price, $element ) {
        $price = str_replace( ',', '.', $price );
        $adjust_map = array(
            'laptops' => 1.4,
            'smartphones' => 1.6,
            'keyboards' => 1.5,
            'default' => 1.3
        );
    
        return ( array_key_exists( $element, $adjust_map ) ) ? ( round( ($price + 3.5) * $adjust_map[ $element ], 2 ) ) : ( round( ($price + 3.5) * $adjust_map[ 'default' ], 2 ) );
    }
    • This reply was modified 3 years, 9 months ago by bigdrop.gr.
    Plugin Author WP All Import

    (@wpallimport)

    Hi @bigdropgr,

    Your code seems like it should work, but I would suggest switching from the ternary operator to a regular IF so that it’s easier to read and manage/change in the case that it doesn’t work as expected. For example (note: this is untested):

    function price_adjust_import( $price, $element ) {
    	$price = str_replace( ',', '.', $price );
    	$adjust_map = array(
    		'laptops' => 1.4,
    		'smartphones' => 1.6,
    		'keyboards' => 1.5,
    		'default' => 1.3
    	);
    
    	$price = $price + 3.5;
    
    	if ( array_key_exists( $element, $adjust_map ) ) {
    		$price = $price * $adjust_map[ $element ];
    	} else {
    		$price = $price * $adjust_map['default'];
    	}
    	
    	return round( $price, 2 );
    }
    Plugin Author WP All Import

    (@wpallimport)

    Hi @bigdropgr,

    I’m marking this as resolved since it’s been inactive for a while. Please open a new thread if you still have questions.

Viewing 4 replies - 1 through 4 (of 4 total)
  • The topic ‘Per category “if” price adjust’ is closed to new replies.