我正在开发一个模块,以接收在我的Magento商店销售的公司的佣金。它已经在工作,但需要添加一个我没有得到的新功能。 如果任何公司的申请大于" X"我需要在佣金中增加额外的价值。 我做的方式不起作用:
foreach ($order->getAllVisibleItems() as $key => $item)
{
$product = Mage::getModel('catalog/product')->load($item->getProductId());
$price = $item->getPrice();
$valor_comissao = (int)$product->getAttributeText('comissao_vendedor')/100;
$comissao_valor2= $price-($price*$valor_comissao);
$qty = $item->getQtyOrdered();
$valor_pedido= ($price*$qty);
if($valor_pedido > 150) {
$comissao_valor= ($comissao_valor2*$qty-17);
} else {
$comissao_valor=($comissao_valor2*$qty-2);
}
$comissoes[] = array (
'Razao' => 'Produto '.$item->getName().' id '.$item->getProductId().' x '.$item->getQtyToInvoice().' sku: '. $item->getSku(),
'Login' => $product->getAttributeText('login'),
'ValorFixo' => $comissao_valor
);
}
然后,只有当产品从$ 150.00开始增加价值时,如果您有两个选择,花费$ 100.00,则不会添加该值。如果品牌的整个订单超过$ 150.00,我需要添加价值。
我试图遵循的逻辑如下:
我想知道是否有人经历过类似的事情并且可以帮助我。
荷。
答案 0 :(得分:0)
获取订单的总价值
您可以通过以下方式检索订单总数:
$order->getGrandTotal()
按标记过滤,即按品牌划分的总价值
我建议使用Magento的资源模型对象并在其上构建查询。
这篇文章展示了如何做到这一点:https://stackoverflow.com/a/5139391/3784145
注意
Mage::getModel('catalog/product')->getCollection()
可以使用代替
Mage::getResourceModel('sales/order_collection')
模型和资源之间差异的解释:
https://magento.stackexchange.com/a/4579
如果该产品是超过" x"并且她还没有收到额外的价值,加上运费
我真的不知道你的意思:如果该产品是超过" x"
的品牌但我认为这需要另一个集合查询。