TL; DR: czy istnieje sposób na debugowanie ładowania układu? Jak wierzę, układ jednego modułu jest w konflikcie z innym.
Powiązane z poprzednim pytaniem, które zadałem: Jak zrobić układ modułu, aby był wyświetlany na wszystkich motywach
Z powodzeniem załadowałem mój moduł do lokalnego środowiska testowego (zwanego też moim komputerem programistycznym), przetestowałem przełączanie między 3 różnymi motywami i jest w porządku. Następnie zaktualizowałem moduł w testowym lub „przedprodukcyjnym” środowisku, które mamy, gdzie jest wiele różnych modułów, niektóre zastrzeżone przez nas. W tym środowisku moduł nie pokazuje, co jest potrzebne na stronie głównej produktu. Po kilku testach w końcu doszedłem do wniosku, że problemem powinien być proces ładowania układu.
Czy jest więc sposób, w jaki mogę debugować ładowanie układu, jak różne moduły zastępują lub dodają własne bloki? Chodzi mi o to, że uważam, że istnieje co najmniej jeden moduł, który powinien kolidować z moim. Ponieważ mamy tak wiele modułów, szukam innego podejścia niż wyłączanie modułów jeden po drugim i sprawdzanie, który jest problematyczny.
Mój plik config.xml to:
<?xml version="1.0" encoding="UTF-8"?>
<config>
<modules>
<Dts_Banners>
<version>0.1.0</version>
</Dts_Banners>
</modules>
<global>
<blocks>
<banners>
<class>Dts_Banners_Block</class>
</banners>
</blocks>
....
<events>
<controller_action_layout_load_before>
<observers>
<attributesethandle>
<class>Dts_Banners_Model_Observer</class>
<method>addAttributeSetHandle</method>
</attributesethandle>
</observers>
</controller_action_layout_load_before>
</events>
</global>
....
</config>
Plik mojego obserwatora:
<?php
class Dts_Banners_Model_Observer
{
/**
* Checks if the search text on the list of active campaigns (dts_banners_admin table) has some of the comma separated text on the product name
* If text found, add a layout handle PRODUCT_CAMPAIGN_BANNER after PRODUCT_TYPE_<product_type_id> handle
* This handle is handled on the banners.xml layout file that triggers the use of the Front.php frontend block
*
* Event: controller_action_layout_load_before
*
* @param Varien_Event_Observer $observer
*/
public function addAttributeSetHandle(Varien_Event_Observer $observer) {
$product = Mage::registry('current_product');
if (!($product instanceof Mage_Catalog_Model_Product)) return;
....
....
}
To jest mój plik układu:
<?xml version="1.0" encoding="UTF-8"?>
<layout version="0.1.0">
<default>
<reference name="content">
<block type="banners/front" name="banners.front" as="banners_front" template="banners/product.phtml" before="-"/>
</reference>
</default>
</layout>
Wcześniej miałem nieco inny, w którym zamiast <default></default>
miałem <Product_Campaign_Banner></Product_Campaign_Banner>
. To też działało.
Mój plik product.phtml:
<div class="visual">
<?php echo $this->showCampaign(); ?>
</div>
product.phtml
Plik nie jest załadowany, a zatem showCampaign
nie jest stracony i nie ma gdzie wszystkie potrzebne HTML jest tworzony.