Wednesday, 29 August 2018

Cart item price calculation, based on different basic prices in Woocommerce

In Woocommerce, I use custom fields to calculate the price of a product, based on this code - Cart item price calculation, based on the chosen “days” custom field in Woocommerce. Many thanks for the help of LoicTheAztec.

// HERE your rental days settings
function get_rental_days_options() {
    return array(
            '2' => __("2 Days", "woocommerce"),
            '4' => __("4 Days", "woocommerce"),
    );
}

// Add a custom field before single add to cart
add_action('woocommerce_before_add_to_cart_button', 'display_single_product_custom_fields', 5);

function display_single_product_custom_fields() {
    // Get the rental days data options
    $options = array('' => __("Choosen period", "woocommerce")) + get_rental_days_options();

    echo '<div class="custom-text text"> < h3 > '.__("Rental", "woocommerce").
    ' < /h3> < label > '.__("Start Date", "woocommerce").
    ': < /label> < input type = "date"
    name = "rental_date"
    value = ""
    class = "rental_date" / >
            < label > Period: < /label> < select class = "rental-days"
    id = "rental-days"
    name = "rental_days" > ';

    foreach($options as $key => $option) {
            echo '<option value="'.$key.
            '">'.$option.
            '</option>';
    }

    echo '</select> < /div>';
}

// Get custom field value, calculate new item price, save it as custom cart item data
add_filter('woocommerce_add_cart_item_data', 'add_custom_field_data', 20, 3);

function add_custom_field_data($cart_item_data, $product_id, $variation_id) {
    // HERE set the percentage rate to be applied to get the new price
    $percentage = 2;

    if (isset($_POST['rental_date']) && !empty($_POST['rental_date'])) {
            $cart_item_data['custom_data']['start_date'] = $_POST['rental_date'];
    }

    if (isset($_POST['rental_days']) && !empty($_POST['rental_days'])) {
            $cart_item_data['custom_data']['rental_days'] = esc_attr($_POST['rental_days']);

            $_product_id = $variation_id > 0 ? $variation_id : $product_id;

            $product = wc_get_product($_product_id); // The WC_Product Object
            $base_price = (float) $product - > get_regular_price(); // Get the product regular price

            $price_rate = $cart_item_data['custom_data']['rental_days'] * $percentage / 100;

            $cart_item_data['custom_data']['base_price'] = $base_price;
            $cart_item_data['custom_data']['new_price'] = $base_price * $price_rate;
    }

    // Make each cart item unique
    if (isset($cart_item_data['custom_data']['rental_days']) || isset($cart_item_data['custom_data']['start_date'])) {
            $cart_item_data['custom_data']['unique_key'] = md5(microtime().rand());
    }

    return $cart_item_data;
}

// Set the new calculated cart item price
add_action('woocommerce_before_calculate_totals', 'extra_price_add_custom_price', 20, 1);

function extra_price_add_custom_price($cart) {
    if (is_admin() && !defined('DOING_AJAX'))
            return;

    foreach($cart - > get_cart() as $cart_item) {
            if (isset($cart_item['custom_data']['new_price']))
                    $cart_item['data'] - > set_price((float) $cart_item['custom_data']['new_price']);
    }
}

// Display cart item custom price details
add_filter('woocommerce_cart_item_price', 'display_cart_items_custom_price_details', 20, 3);

function display_cart_items_custom_price_details($product_price, $cart_item, $cart_item_key) {
    if (isset($cart_item['custom_data']['base_price'])) {
            $product = $cart_item['data'];
            $base_price = $cart_item['custom_data']['base_price'];
            $product_price = wc_price(wc_get_price_to_display($product, array('price' => $base_price))).
            '<br>';

            if (isset($cart_item['custom_data']['rental_days'])) {
                    $rental_days = get_rental_days_options();
                    $product_price. = $rental_days[$cart_item['custom_data']['rental_days']];
            }
    }
    return $product_price;
}

// Display in cart item the selected date
add_filter('woocommerce_get_item_data', 'display_custom_item_data', 10, 2);

function display_custom_item_data($cart_item_data, $cart_item) {
    if (isset($cart_item['custom_data']['start_date'])) {
            $cart_item_data[] = array(
                    'name' => __("Rental start date", "woocommerce"),
                    'value' => date('d.m.Y', strtotime($cart_item['custom_data']['start_date'])),
            );
    }

    if (isset($cart_item['custom_data']['rental_days'])) {
            $rental_days = get_rental_days_options();
            $cart_item_data[] = array(
                    'name' => __("Rental period", "woocommerce"),
                    'value' => $rental_days[$cart_item['custom_data']['rental_days']],
            );
    }

    return $cart_item_data;
}

// Save and display custom field in orders and email notifications (everywhere)
add_action('woocommerce_checkout_create_order_line_item', 'custom_fields_update_order_item_meta', 20, 4);

function custom_fields_update_order_item_meta($item, $cart_item_key, $values, $order) {
    if (isset($values['custom_data']['date'])) {
            $date = date('d.m.Y', strtotime($values['custom_data']['date']));
            $item - > update_meta_data(__('Start date', 'woocommerce'), $date);
    }
    if (isset($values['custom_data']['rental_days'])) {
            $rental_days = get_rental_days_options();
            $item - > update_meta_data(__('Rental period', 'woocommerce'), $rental_days[$values['custom_data']['rental_days']]);
    }
}

I did not expect a new condition for calculating the user's price (( This is the last.

If the user buys a product with a base price greater than 6,660, then the standard calculation follows from the code shown above.

If the user buys a product whose base price is less than 6,660, then the new price is 999 per day. Next, the user selects the rental period. If he chooses 2 days, then 999 * 2. If he chooses 4 days, then 999 * 4.

As I understand it, I need to add the conditions if base_price> 6600 (hereafter goes the standard calculation code) and if base_price <6600 (then count based on the user's choice of 999 * 2 or 999 * 4).

I need to make a conclusion of price ['new_price'] next to the base price on the product single page.

But I do not quite understand how to implement it correctly.

I shall be very glad of your help!



from Cart item price calculation, based on different basic prices in Woocommerce

No comments:

Post a Comment