-
-
Notifications
You must be signed in to change notification settings - Fork 17
/
Copy pathItemResolver.php
126 lines (101 loc) · 4.56 KB
/
ItemResolver.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
<?php
declare(strict_types=1);
namespace Setono\SyliusAnalyticsPlugin\Resolver\Item;
use Psr\EventDispatcher\EventDispatcherInterface;
use Setono\GoogleAnalyticsEvents\Event\Item\Item;
use Setono\SyliusAnalyticsPlugin\Event\ItemResolved;
use Setono\SyliusAnalyticsPlugin\Resolver\Brand\BrandResolverInterface;
use Setono\SyliusAnalyticsPlugin\Resolver\Category\CategoryResolverInterface;
use Setono\SyliusAnalyticsPlugin\Resolver\Variant\VariantResolverInterface;
use Setono\SyliusAnalyticsPlugin\Util\FormatAmountTrait;
use Sylius\Component\Channel\Context\ChannelContextInterface;
use Sylius\Component\Core\Calculator\ProductVariantPricesCalculatorInterface;
use Sylius\Component\Core\Model\OrderItemInterface;
use Sylius\Component\Core\Model\ProductInterface;
use Sylius\Component\Core\Model\ProductVariantInterface;
use Sylius\Component\Product\Resolver\ProductVariantResolverInterface;
use Webmozart\Assert\Assert;
final class ItemResolver implements ItemResolverInterface
{
use FormatAmountTrait;
private EventDispatcherInterface $eventDispatcher;
private ProductVariantResolverInterface $productVariantResolver;
private ChannelContextInterface $channelContext;
private ProductVariantPricesCalculatorInterface $productVariantPricesCalculator;
private VariantResolverInterface $variantResolver;
private CategoryResolverInterface $categoryResolver;
private BrandResolverInterface $brandResolver;
public function __construct(
EventDispatcherInterface $eventDispatcher,
ProductVariantResolverInterface $productVariantResolver,
ChannelContextInterface $channelContext,
ProductVariantPricesCalculatorInterface $productVariantPricesCalculator,
VariantResolverInterface $variantResolver,
CategoryResolverInterface $categoryResolver,
BrandResolverInterface $brandResolver
) {
$this->eventDispatcher = $eventDispatcher;
$this->productVariantResolver = $productVariantResolver;
$this->channelContext = $channelContext;
$this->productVariantPricesCalculator = $productVariantPricesCalculator;
$this->variantResolver = $variantResolver;
$this->categoryResolver = $categoryResolver;
$this->brandResolver = $brandResolver;
}
public function resolveFromOrderItem(OrderItemInterface $orderItem): Item
{
$variant = $orderItem->getVariant();
Assert::notNull($variant);
$item = Item::create()
->setItemId($variant->getCode())
->setItemName($orderItem->getProductName())
->setItemVariant($this->variantResolver->resolve($variant))
->setItemBrand($this->brandResolver->resolveFromProductVariant($variant))
->setQuantity($orderItem->getQuantity())
->setPrice(self::formatAmount($orderItem->getFullDiscountedUnitPrice()))
;
$this->populateCategories($item, $this->categoryResolver->resolveFromProductVariant($variant));
$this->eventDispatcher->dispatch(new ItemResolved($item, [
'orderItem' => $orderItem,
'variant' => $variant,
]));
return $item;
}
public function resolveFromProduct(ProductInterface $product): Item
{
/** @var ProductVariantInterface|null $variant */
$variant = $this->productVariantResolver->getVariant($product);
Assert::isInstanceOf($variant, ProductVariantInterface::class);
$item = Item::create()
->setItemId($product->getCode())
->setItemName($product->getName())
->setItemBrand($this->brandResolver->resolveFromProduct($product))
;
try {
$item->setPrice(self::formatAmount($this->productVariantPricesCalculator->calculate($variant, [
'channel' => $this->channelContext->getChannel(),
])));
} catch (\Throwable $e) {
}
$this->populateCategories($item, $this->categoryResolver->resolveFromProduct($product));
$this->eventDispatcher->dispatch(new ItemResolved($item, [
'product' => $product,
'variant' => $variant,
]));
return $item;
}
/**
* @param list<string> $categories
*/
private function populateCategories(Item $item, array $categories): void
{
foreach ($categories as $idx => $category) {
// an item only have five categories available
if ($idx > 4) {
break;
}
$method = sprintf('setItemCategory%s', 0 === $idx ? '' : (string) ($idx + 1));
$item->{$method}($category);
}
}
}