• Resolved bigdrop.gr

    (@bigdropgr)


    Hi,

    I have found this post here https://www.ads-software.com/support/topic/adjust-price-by-category-import-element/ and applied it to my site.

    I am building a tire shop and I am trying to adjust prices based on the manufacturer.
    So I have written the bellow code:

    <?php
    // Sprint netprice update
    function price_adjust_import( $price, $element ) {
        $adjust_map = array(
            'B.F. GOODRICH' => 1.13,
            'BRIDGESTONE' => 1.15,
            'CONTINENTAL' => 1.13,
            'DUNLOP' => 1.17,
            'FULDA' => 1.13,
            'GISLAVED' => 1.20,
            'GOODYEAR' => 1.13,
            'HANKOOK' => 1.15,
            'MICHELIN' => 1.13,
            'PIRELLI' => 1.13,
            'TOYO' => 1.18,
            'UNIROYAL' => 1.13,
            'VREDESTEIN' => 1.17,
            'YOKOHAMA' => 1.16
        );
    
        return ( array_key_exists( $element, $adjust_map ) ) ? ($price * 1.24 * $adjust_map[ $element ] ) : $price;
    }
    ?>

    Then on my xml file I have these values:
    {nettprice[1]} (The net tyre price)
    and
    {branddescription[1]} (The brand name)

    I use this shortcode for displaying the adjust price:
    [price_adjust_import({nettprice[1]},{branddescription[1]})]

    In my function I want to adjust the price based on the brand and multiply it by 1.24. Because 24% is the VAT.

    The above code is not working properly.
    The result prices are wrong.

    For two different brands, for which the $adjust_map[ $element ] is equal to 1.13 (Michelin and Uniroyal), the result is complete different.

    In category A with product price 68,89 the result after the price is adjust is 95.2816 (which is wrong)

    In category B with product price 45,50 the result after the price is adjust is 63054 (which is also wrong).

    What am I doing wrong?

    • This topic was modified 4 years, 5 months ago by bigdrop.gr.
    • This topic was modified 4 years, 5 months ago by bigdrop.gr.
Viewing 4 replies - 1 through 4 (of 4 total)
  • Plugin Author WP All Import

    (@wpallimport)

    Hi @bigdropgr,

    Based on your description, the problem is that the prices are using a comma as the decimal separator. If you use str_replace() in your code to convert it to a period before the calculation, it should fix this. Example:

    $price = str_replace( ',', '.', $price );

    Keep in mind that this is a basic example and you may need to adjust it.

    Thread Starter bigdrop.gr

    (@bigdropgr)

    Hi,

    Thank you for your reply. I made the changes that you suggested to my code.
    It almost works.
    What I mean “almost”.. The majority of the products the price is calculated properly but in some cases the numbers are wrong.

    In one case the product netprice is 59 and after my maths it should be 84.134 but instead it is 84134. It skips the period. So I have products that instead of costing 84 Euros they cost 84 thousands euros.

    My exact code is:

    function price_adjust_import( $price, $element ) {
        $price = str_replace( ',', '.', $price );
        $adjust_map = array(
            'ATLAS' => 1.426,
            'AVON' => 1.426,
            'B.F. GOODRICH' => 1.426,
            'BARUM' => 1.426,
            'BRIDGESTONE' => 1.426,
            'CONTINENTAL' => 1.426,
            'COOPER' => 1.426,
            'DEBICA' => 1.426,
            'DELINTE' => 1.426,
            'DIVERSEN' => 1.426,
            'DOUBLE STAR' => 1.426,
            'DUNLOP' => 1.426,
            'DURATURN' => 1.426,
            'FALKEN' => 1.426,
            'FIREMAX' => 1.426,
            'FIRESTONE' => 1.426,
            'FORTUNA' => 1.426,
            'FULDA' => 1.426,
            'GAJAH TUNGGAL' => 1.426,
            'GISLAVED' => 1.426,
            'GOFORM' => 1.426,
            'GOODRIDE' => 1.426,
            'GOODYEAR' => 1.426,
            'HANKOOK' => 1.426,
            'IMPERIAL' => 1.426,
            'KLEBER' => 1.426,
            'KUMHO' => 1.426,
            'LANDSAIL' => 1.426,
            'LINGLONG' => 1.426,
            'MASTER-STEEL' => 1.426,
            'METEOR' => 1.426,
            'METZELER' => 1.426,
            'MICHELIN' => 1.426,
            'MILESTONE' => 1.426,
            'MINERVA' => 1.426,
            'NANKANG' => 1.426,
            'NEXEN' => 1.426,
            'NOKIAN' => 1.426,
            'PIRELLI' => 1.426,
            'ROADHOG' => 1.426,
            'SEMPERIT' => 1.426,
            'SUPERIA' => 1.426,
            'TOYO' => 1.426,
            'TRISTAR' => 1.426,
            'TYFOON' => 1.426,
            'UNIGRIP' => 1.426,
            'UNIROYAL' => 1.426,
            'VREDESTEIN' => 1.426,
            'WANLI' => 1.426,
            'WESTLAKE' => 1.426,
            'YOKOHAMA' => 1.426
        );
    
        return ( array_key_exists( $element, $adjust_map ) ) ? ($price * $adjust_map[ $element ] ) : $price;
    }

    For the same brand tires (Goodyear) it calculates hundreds of product prices correct and a couple of them wrong.

    What might be the problem now?

    Plugin Author WP All Import

    (@wpallimport)

    Hi @bigdropgr,

    Try changing the ‘return’ line to round the price after the calculation:

    return ( array_key_exists( $element, $adjust_map ) ) ? ( round( $price * $adjust_map[ $element ], 2 ) ) : $price;

    Thread Starter bigdrop.gr

    (@bigdropgr)

    Thank you very much!!
    That worked like a charm!!

Viewing 4 replies - 1 through 4 (of 4 total)
  • The topic ‘Change price based on category’ is closed to new replies.