Hum*_*Hum 6 magento promotion-code
我想检查产品是否有促销活动,然后将促销标签贴在类别列表页面上的该产品上。但我不知道如何循环遍历所有购物车规则并检索与每个规则关联的产品/类别。
编辑
谢谢 Seanbreeden,但我无法从 中提取 sku $conditions。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;}}}}}
Run Code Online (Sandbox Code Playgroud)
但是当我循环 $conditions 时
$rules = Mage::getResourceModel('salesrule/rule_collection')->load();
foreach ($rules as $rule) {
$conditions = $rule->getConditionsSerialized();
foreach ($conditions as $condition) {
var_dump($condition);
}
}
Run Code Online (Sandbox Code Playgroud)
它没有显示任何内容,所以不知道如何在这里提取 sku。
EDIT2 正如 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;
Run Code Online (Sandbox Code Playgroud)
然后检查列表页面中的 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_related_sku。然后,当您显示目录时,您会检查 sku 以及规则是否仍然有效。这个解决方案将是最简单的一个:-)
| 归档时间: |
|
| 查看次数: |
20037 次 |
| 最近记录: |