1

我在 WooCommerce 中使用插件 GravityForms 的价格计算确实有一个相当复杂的问题。

我主要销售提供雕刻选项的定制产品。这就是我需要 GravityForms 的原因。

我想用标题下方选择的可变价格替换标准的 woocommerce 价格。为此,我使用了由

@Loictheaztec 用选择的变化价格替换可变价格范围

这是我在我的functions.php

// Utility function to get the default variation (if it exist)
function get_default_variation( $product ){
$attributes_count = count($product->get_variation_attributes());
$default_attributes = $product->get_default_attributes();
// If no default variation exist we exit
if( $attributes_count != count($default_attributes) )
    return false;

// Loop through available variations
foreach( $product->get_available_variations() as $variation ){
    $found = true;
    // Loop through variation attributes
    foreach( $variation['attributes'] as $key => $value ){
        $taxonomy = str_replace( 'attribute_', '', $key );
        // Searching for a matching variation as default
        if( isset($default_attributes[$taxonomy]) && 
$default_attributes[$taxonomy] != $value ){
            $found = false;
            break;
        }
    }
    // If we get the default variation
    if( $found ) {
        $default_variaton = $variation;
        break;
    }
    // If not we continue
    else {
        continue;
    }
}
return isset($default_variaton) ? $default_variaton : false;
}

add_action( 'woocommerce_before_single_product', 
'move_variations_single_price', 1 );
function move_variations_single_price(){
global $product, $post;

if ( $product->is_type( 'variable' ) ) {
    // removing the variations price for variable products
    remove_action( 'woocommerce_single_product_summary', 
'woocommerce_template_single_price', 10 );

    // Change location and inserting back the variations price
    add_action( 'woocommerce_single_product_summary', 
'replace_variation_single_price', 10 );
}
}

function replace_variation_single_price(){
global $product;

// Main Price
$prices = array( $product->get_variation_price( 'min', true ), 
$product->get_variation_price( 'max', true ) );
$active_price = $prices[0] !== $prices[1] ? sprintf( __( 'From: %1$s', 
'woocommerce' ), wc_price( $prices[0] ) ) : wc_price( $prices[0] );

// Sale Price
$prices = array( $product->get_variation_regular_price( 'min', true ), 
$product->get_variation_regular_price( 'max', true ) );
sort( $prices );
$regular_price = $prices[0] !== $prices[1] ? sprintf( __( 'From: 
%1$s', 'woocommerce' ), wc_price( $prices[0] ) ) : wc_price( 
$prices[0] );

if ( $active_price !== $regular_price && $product->is_on_sale() ) {
    $price = '<del>' . $regular_price . $product->get_price_suffix() . 
'</del> <ins>' . $active_price . $product->get_price_suffix() . 
'</ins>';
} else {
    $price = $regular_price;
}

// When a default variation is set for the variable product
if( get_default_variation( $product ) ) {
    $default_variaton = get_default_variation( $product );
    if( ! empty($default_variaton['price_html']) ){
        $price_html = $default_variaton['price_html'];
    } else {
        if ( ! $product->is_on_sale() )
            $price_html = $price = 
wc_price($default_variaton['display_price']);
        else
            $price_html = $price;
    }
    $availiability = $default_variaton['availability_html'];
} else {
    $price_html = $price;
    $availiability = '';
}
// Styles ?>
<style>
    div.woocommerce-variation-price,
    div.woocommerce-variation-availability,
    div.hidden-variable-price {
        height: 0px !important;
        overflow:hidden;
        position:relative;
        line-height: 0px !important;
        font-size: 0% !important;
    }
</style>
<?php // Jquery ?>
<script>
jQuery(document).ready(function($) {
    var a = 'div.wc-availability', p = 'p.price';

    $('select').blur( function(){
        if( '' != $('input.variation_id').val() ){
            if($(a).html() != '' ) $(a).html('');
            $(p).html($('div.woocommerce-variation-price > 
span.price').html());
            $(a).html($('div.woocommerce-variation- 
availability').html());
        } else {
            if($(a).html() != '' ) $(a).html('');
            $(p).html($('div.hidden-variable-price').html());
        }
    });
});
</script>
<?php

echo '<p class="price">'.$price_html.'</p>
<div class="wc-availability">'.$availiability.'</div>
<div class="hidden-variable-price" >'.$price.'</div>';
}

让我们澄清一下事情。请查看屏幕截图以了解 woocommerce 变体和 GravityForm 字段的位置。

Woocommerce 可变价格和 GravityForms 可变价格

woocommerce价格的css类为:

`<p class="price">
<span class="woocommerce-Price-amount amount">45&nbsp;</span>
<span class="woocommerce-Price-currencySymbol">€&lt;/span>
<span class="mwst"> inkl. MwSt.</span>
</p>`

GravityForms 价格的 css 类是:

<li class="gfield">
  <label class="gfield_label">Total</label>
    <div class="ginput_container">
        <span class="formattedTotalPrice ginput_total">45,00&nbsp €&lt;/span>
    </div>
</li>

现在让我们从 woocommerce 字段中选择价格变化。

已选择 Woocommerce 可变价格

这很好地输出了顶部和底部的 woocommerce 的选定变化价格。

所以现在让我们开始问题并从 GravityForms 字段中选择一个变化价格。

GravityForms 选择的价格变化

如您所见,顶部的价格不会识别价格变化。但显示在下端的价格显示正确。

现在的问题是,是否可以修改通过选择的变化价格替换可变价格的代码,使其也能识别通过 GravityForms 进行的价格变化?

更新

我搜索了重力表格的文档以找到价格标签的过滤钩。我找到了这个:

GravityForms 文档 - gform_product_price 过滤器

然后我检查了如果我在functions.php我的子主题文件中使用这个函数会发生什么。

add_filter( 'gform_product_price', 'set_price_label', 10, 2 );
function set_price_label( ) {
echo 'Some output somewhere?';   
}

或者这个函数

add_filter( 'gform_product_price', 'set_price_label_test', 10, 2 );
function set_price_label_test( $sublabel, $form_id ) {
return 'Cost';
}

不幸的是,什么也没发生。

这是结果的图像。 使用 GravityForms set_price_label 过滤器的结果

4

0 回答 0