magento - 显示购物车规则和与每个规则关联的产品类别的集合

标签 magento promotion-code

我想检查产品是否有促销事件,然后在类别列表页面上将该产品上贴上促销标签。但我不知道如何循环遍历所有购物车规则并检索与每个规则关联的产品/类别。

已编辑

谢谢 Seanbreeden,但我无法从 $conditions 中提取 sku。 var_dump($conditions); 显示:

{s:4:"type";s:32:"salesrule/rule_condition_combine";s:9:"attribute";N;s:8:"operator";N;s:5:"value";s:1:"1";s:18:"is_value_processed";N;s:10:"aggregator";s:3:"all";}a:7:{s:4:"type";s:32:"salesrule/rule_condition_combine";s:9:"attribute";N;s:8:"operator";N;s:5:"value";s:1:"1";s:18:"is_value_processed";N;s:10:"aggregator";s:3:"all";s:10:"conditions";a:1:{i:0;a:7:{s:4:"type";s:42:"salesrule/rule_condition_product_subselect";s:9:"attribute";s:3:"qty";s:8:"operator";s:2:">=";s:5:"value";s:1:"1";s:18:"is_value_processed";N;s:10:"aggregator";s:3:"all";s:10:"conditions";a:1:{i:0;a:5:{s:4:"type";s:32:"salesrule/rule_condition_product";s:9:"attribute";s:12:"category_ids";s:8:"operator";s:2:"==";s:5:"value";s:2:"23";s:18:"is_value_processed";b:0;}}}}}a:7:{s:4:"type";s:32:"salesrule/rule_condition_combine";s:9:"attribute";N;s:8:"operator";N;s:5:"value";s:1:"1";s:18:"is_value_processed";N;s:10:"aggregator";s:3:"all";s:10:"conditions";a:2:{i:0;a:5:{s:4:"type";s:32:"salesrule/rule_condition_address";s:9:"attribute";s:13:"base_subtotal";s:8:"operator";s:2:">=";s:5:"value";s:2:"45";s:18:"is_value_processed";b:0;}i:1;a:7:{s:4:"type";s:42:"salesrule/rule_condition_product_subselect";s:9:"attribute";s:3:"qty";s:8:"operator";s:2:">=";s:5:"value";s:1:"1";s:18:"is_value_processed";N;s:10:"aggregator";s:3:"all";s:10:"conditions";a:1:{i:0;a:5:{s:4:"type";s:32:"salesrule/rule_condition_product";s:9:"attribute";s:3:"sku";s:8:"operator";s:2:"==";s:5:"value";s:46:"test-config, BLFA0968C-BK001, BLFA0968C-CR033X";s:18:"is_value_processed";b:0;}}}}}a:6:{s:4:"type";s:32:"salesrule/rule_condition_combine";s:9:"attribute";N;s:8:"operator";N;s:5:"value";s:1:"1";s:18:"is_value_processed";N;s:10:"aggregator";s:3:"all";}a:6:{s:4:"type";s:32:"salesrule/rule_condition_combine";s:9:"attribute";N;s:8:"operator";N;s:5:"value";s:1:"1";s:18:"is_value_processed";N;s:10:"aggregator";s:3:"all";}a:7:{s:4:"type";s:32:"salesrule/rule_condition_combine";s:9:"attribute";N;s:8:"operator";N;s:5:"value";s:1:"1";s:18:"is_value_processed";N;s:10:"aggregator";s:3:"all";s:10:"conditions";a:1:{i:0;a:7:{s:4:"type";s:42:"salesrule/rule_condition_product_subselect";s:9:"attribute";s:3:"qty";s:8:"operator";s:2:">=";s:5:"value";s:1:"1";s:18:"is_value_processed";N;s:10:"aggregator";s:3:"all";s:10:"conditions";a:1:{i:0;a:5:{s:4:"type";s:32:"salesrule/rule_condition_product";s:9:"attribute";s:3:"sku";s:8:"operator";s:2:"==";s:5:"value";s:16:"BLFA0968C-CR033X";s:18:"is_value_processed";b:0;}}}}}

但是当我循环 $conditions 即

$rules = Mage::getResourceModel('salesrule/rule_collection')->load();

foreach ($rules as $rule) {
    $conditions = $rule->getConditionsSerialized();
    foreach ($conditions as $condition) {
        var_dump($condition);
    }
}

它没有显示任何内容,所以不知道如何在这里提取 sku。

编辑2 正如 Alaxandre 所建议的,我没有使用非序列化方法。我现在这样做:

$rules = Mage::getResourceModel('salesrule/rule_collection')->load();

foreach ($rules as $rule) {
    if ($rule->getIsActive()) {
        //print_r($rule->getData());
        $rule = Mage::getModel('salesrule/rule')->load($rule->getId()); 

        $conditions = $rule->getConditions();
        $conditions = $rule->getConditions()->asArray();

        foreach( $conditions['conditions'] as $_conditions ):
            foreach( $_conditions['conditions'] as $_condition ):
                $string = explode(',', $_condition['value']);
                for ($i=0; $i<count($string); $i++) {
                    $skus[] = trim($string[$i]);
                }
            endforeach;
        endforeach;
    }
}
return $skus;

然后检查列表页面中的 sku 是否与 $skus 数组中匹配,然后显示标签。但这种方法也有局限性。我正在考虑另一种方法(我不确定这是否可行)。 考虑创建一个新表(用于保存销售规则产品)。每次保存销售规则时,捕获保存规则事件并使用规则名称和所有关联产品更新表。然后在列表页面检查该表,如果表中存在产品,则显示相应的标签。现在我认为该事件是adminhtml_controller_salesrule_prepare_save(不是100%确定),但我不知道如何从观察者中的规则条件获取sku以保存在新表中。

最佳答案

我建议你这样做。当您将产品放入购物车时,会检查每个规则以计算最终价格和折扣。您可以知道哪些规则适用于购物车的每件商品。在表 sales_flat_quote_item 中,您有列 applied_rule_ids。我认为你可以在 php 中通过函数 getAllItemsInCart 或类似的东西来访问它(你必须找出来)。执行 $item->getAppliedRuleIds() 后,最后您可以获得应用于项目(产品)的规则名称。

祝你好运:)

编辑:

我再次阅读了您的要求,我认为我的回答不符合您的要求。 你的情况更复杂。对于目录页面上的每个产品,您都必须应用网站的所有规则。但是 Mage_SalesRule_Model_Validator 处理的是预期项目而不是产品... 如果您有很多规则,此任务会减慢您的目录速度,这确实不好!最好的办法是将规则标签的结果缓存在数据库中,可能在表 catalog_category_product 中或...(甚至更好地自动生成此缓存)。

编辑2:

另一种可能性是在规则创建中添加一个新字段,您可以在其中手动设置相关产品 (sku)。您可以将此数据保存在表 salesrule 或新表 salesrule_lated_sku 中。 然后,当您显示目录时,您会检查 sku 以及规则是否仍然有效。 这个解决方案将是最简单的一个:-)

关于magento - 显示购物车规则和与每个规则关联的产品类别的集合,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9483072/

相关文章:

Magento - 如何扩展前端 Controller

php - 如何在产品概览页面 - Magento 中隐藏货币代码?

php - Magento - 预览产品但需要登录才能购买

php - 尝试在 php 中为在线商店实现促销代码框

ios - 即时应用商店促销代码?

android - 通过促销代码进行的应用内购买返回空的开发人员有效负载字符串

Magento - 带有系统配置的模块,我该如何保存?

css - 主页上的 Logo 位于与其他页面不同的位置

ios - 如何为付费 iOS 应用程序生成大量促销代码?

Android:订阅的促销代码?