@@ -64,17 +64,8 @@ public function validate(DesignConfigInterface $designConfig)
64
64
}
65
65
66
66
foreach ($ elements as $ name => $ data ) {
67
- // Load template object by configured template id
68
- $ template = $ this ->templateFactory ->create ();
69
- $ template ->emulateDesign ($ designConfig ->getScopeId ());
70
67
$ templateId = $ data ['value ' ];
71
- if (is_numeric ($ templateId )) {
72
- $ template ->load ($ templateId );
73
- } else {
74
- $ template ->loadDefault ($ templateId );
75
- }
76
- $ text = $ template ->getTemplateText ();
77
- $ template ->revertDesign ();
68
+ $ text = $ this ->getTemplateText ($ templateId , $ designConfig );
78
69
// Check if template body has a reference to the same config path
79
70
if (preg_match_all (Template::CONSTRUCTION_TEMPLATE_PATTERN , $ text , $ constructions , PREG_SET_ORDER )) {
80
71
foreach ($ constructions as $ construction ) {
@@ -94,6 +85,37 @@ public function validate(DesignConfigInterface $designConfig)
94
85
}
95
86
}
96
87
88
+ /**
89
+ * @param $designConfig
90
+ * @return mixed
91
+ */
92
+ private function getScopeId ($ designConfig )
93
+ {
94
+ if ($ designConfig ->getScope () == 'stores ' ) {
95
+ return $ designConfig ->getScopeId ();
96
+ }
97
+ return false ;
98
+ }
99
+
100
+ /**
101
+ * @param $designConfig
102
+ * @return mixed
103
+ */
104
+ private function getTemplateText ($ templateId , $ designConfig )
105
+ {
106
+ // Load template object by configured template id
107
+ $ template = $ this ->templateFactory ->create ();
108
+ $ template ->emulateDesign ($ this ->getScopeId ($ designConfig ));
109
+ if (is_numeric ($ templateId )) {
110
+ $ template ->load ($ templateId );
111
+ } else {
112
+ $ template ->loadDefault ($ templateId );
113
+ }
114
+ $ text = $ template ->getTemplateText ();
115
+ $ template ->revertDesign ();
116
+ return $ text ;
117
+ }
118
+
97
119
/**
98
120
* Return associative array of parameters.
99
121
*
0 commit comments