如何解决如何访问单个计算产品行项目的所有子组计算项目
我的规则集中有两个定制的计算规则,一个用于单个 PLI 价格,另一个用于总计:
在“calculatePostpaidPrices”中,我创建了多个 ComputedDurationItems(自定义定义的类),它们作为子组存储在单个 ComputedProductLineItem 上。 这种关系可以在这里观察到:
现在在第二条规则“calculatePostpaidTotals”(左侧)中,我试图从第一条规则中获取单个 PLI 的所有持续时间项目,现在有什么方法可以做到这一点(右侧是计算结果视图,它有效美好的):
请注意,子组的制作方式与本食谱中的职责子组相同: https://support.intershop.com/kb/index.php/Display/23V395#l100 但是本手册中没有示例如何在下一个计算规则中检索职责(子组)。
解决方法
在查看了一些内置的平台计算规则后,我诉诸于创建此方法:
private Map<ComputedProductLineItem,Collection<ComputedDurationItem>> mapDurationItemsToComputedPLIs(
CalculationRule<ComputedItem,ComputedItem,LineItemCtnr>.Input input) {
Map<ComputedProductLineItem,Collection<ComputedDurationItem>> durationsMap = new HashMap<>();
Collection<ComputedDurationItem> durationItems = input.getItems(durationsSubGroup);
for (ComputedDurationItem durationItem : durationItems) {
ComputedProductLineItem parentPLI = input.getItem(this.durationsSubGroup.getParentCell(durationItem));
if (!durationsMap.containsKey(parentPLI))
durationsMap.put(parentPLI,new ArrayList<ComputedDurationItem>(1));
durationsMap.get(parentPLI).add(durationItem);
}
return durationsMap;
}
然后我使用创建的地图来获取特定 PLI 的持续时间项目。 基本上,这里的情况是您无法获得 PLI 的“子”项目,但您可以为 DurationItem 或任何其他子组中的项目获得父项目,并在此方法中使用。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。