forked from Hevelop/magento2-patches
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Patch-Magento_Translate-MAGETWO-72301-Github-Static-content-deploy-with-mult.patch
119 lines (111 loc) · 4.18 KB
/
Patch-Magento_Translate-MAGETWO-72301-Github-Static-content-deploy-with-mult.patch
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
--- a/Model/Json/PreProcessor.php
+++ b/Model/Json/PreProcessor.php
@@ -3,15 +3,18 @@
* Copyright © Magento, Inc. All rights reserved.
* See COPYING.txt for license details.
*/
+
namespace Magento\Translation\Model\Json;
+use Magento\Framework\App\AreaList;
+use Magento\Framework\App\ObjectManager;
+use Magento\Framework\TranslateInterface;
+use Magento\Framework\View\Asset\File\FallbackContext;
+use Magento\Framework\View\Asset\PreProcessor\Chain;
use Magento\Framework\View\Asset\PreProcessorInterface;
+use Magento\Framework\View\DesignInterface;
use Magento\Translation\Model\Js\Config;
use Magento\Translation\Model\Js\DataProviderInterface;
-use Magento\Framework\View\Asset\PreProcessor\Chain;
-use Magento\Framework\View\Asset\File\FallbackContext;
-use Magento\Framework\App\AreaList;
-use Magento\Framework\TranslateInterface;
/**
* PreProcessor responsible for providing js translation dictionary
@@ -41,23 +44,30 @@ class PreProcessor implements PreProcessorInterface
* @var TranslateInterface
*/
protected $translate;
+ /**
+ * @var DesignInterface
+ */
+ private $viewDesign;
/**
* @param Config $config
* @param DataProviderInterface $dataProvider
* @param AreaList $areaList
* @param TranslateInterface $translate
+ * @param DesignInterface|null $viewDesign
*/
public function __construct(
Config $config,
DataProviderInterface $dataProvider,
AreaList $areaList,
- TranslateInterface $translate
+ TranslateInterface $translate,
+ DesignInterface $viewDesign = null
) {
$this->config = $config;
$this->dataProvider = $dataProvider;
$this->areaList = $areaList;
$this->translate = $translate;
+ $this->viewDesign = $viewDesign ?: ObjectManager::getInstance()->get(DesignInterface::class);
}
/**
@@ -65,6 +75,7 @@ class PreProcessor implements PreProcessorInterface
*
* @param Chain $chain
* @return void
+ * @throws \Exception
*/
public function process(Chain $chain)
{
@@ -77,7 +88,12 @@ class PreProcessor implements PreProcessorInterface
if ($context instanceof FallbackContext) {
$themePath = $context->getThemePath();
$areaCode = $context->getAreaCode();
- $this->translate->setLocale($context->getLocale());
+
+ $this->viewDesign->setDesignTheme($themePath, $areaCode);
+
+ $this->translate
+ ->setLocale($context->getLocale())
+ ->loadData($areaCode);
}
$area = $this->areaList->getArea($areaCode);
--- a/Test/Unit/Model/Json/PreProcessorTest.php
+++ b/Test/Unit/Model/Json/PreProcessorTest.php
@@ -3,6 +3,7 @@
* Copyright © Magento, Inc. All rights reserved.
* See COPYING.txt for license details.
*/
+
namespace Magento\Translation\Test\Unit\Model\Json;
use Magento\Translation\Model\Js\Config;
@@ -41,7 +42,15 @@ class PreProcessorTest extends \PHPUnit\Framework\TestCase
$this->configMock = $this->createMock(\Magento\Translation\Model\Js\Config::class);
$this->dataProviderMock = $this->createMock(\Magento\Translation\Model\Js\DataProvider::class);
$this->areaListMock = $this->createMock(\Magento\Framework\App\AreaList::class);
- $this->translateMock = $this->getMockForAbstractClass(\Magento\Framework\TranslateInterface::class);
+ $this->translateMock = $this->getMockBuilder(\Magento\Framework\Translate::class)
+ ->disableOriginalConstructor()
+ ->getMock();
+
+ $this->translateMock
+ ->expects($this->once())
+ ->method('setLocale')
+ ->willReturn($this->translateMock);
+
$this->model = new PreProcessor(
$this->configMock,
$this->dataProviderMock,
@@ -97,6 +106,11 @@ class PreProcessorTest extends \PHPUnit\Framework\TestCase
->method('setContentType')
->with('json');
+ $this->translateMock
+ ->expects($this->once())
+ ->method('loadData')
+ ->willReturn($this->translateMock);
+
$this->model->process($chain);
}
}