Yanıtlar:
registration.php
modülünüzün giriş noktasıdır. app/etc/modules/[Namespace]_[Module].xml
Magento 1'in eşdeğeri.
Ama şimdi, modülün kendisinin bir parçası. klasörde ve klasörde de
modüller oluşturmanızı sağlar .
Nereye eklerseniz ekleyin, bu dosya Magento tarafından alınacak ve modülünüz dikkate alınacaktır. app/code
vendor
config.php
sadece isimleri görünür modülü ve statüleri (etkin / devre dışı). Modüle giden bir yol yok. Cevabımda söylediğim gibi, registration.php
dışarıda modüllere sahip olmanızı sağlarapp/code
Magento ver iki şey değişti fark ettim. 1.0.0-beta (Ekim) - Magento sürüm. 2.0.0-rc2
1. registration.php adlı modülün kök klasörüne yeni dosya ekledi ex: -app \ code \ Sugarcode \ Test \ registration.php
<?php
/**
* Copyright © 2015 Magento. All rights reserved.
* See COPYING.txt for license details.
*/
\Magento\Framework\Component\ComponentRegistrar::register(
\Magento\Framework\Component\ComponentRegistrar::MODULE,
'Sugarcode_Test',
__DIR__
);
2. event.xml daha önce değiştirildi. Event.xml dosyasında gözlemci etiketinde yöntem adından bahsediyoruz, şimdi yöntem kaldırıldı.
<?xml version="1.0"?>
<config xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="../../../../../../lib/internal/Magento/Framework/Event/etc/events.xsd">
<event name="sales_order_grid_collection_load_before">
<observer name="sales_order_grid_test" instance="Sugarcode\Test\Observer\Addtest" />
</event>
</config>
ve / ModuleName / Observer klasöründe işlevli bir dosya oluşturmanız gerekir
public function execute()
yani
<?php
namespace Sugarcode\Test\Observer;
class Addtest
{
public function execute(\Magento\Framework\Event\Observer $observer)
{
$obj=$observer->getEvent()->getOrderGridCollection();
$obj->getSelect()->joinLeft(
['testt' => 'testtable'],
"(main_table.entity_id = testt.id)",
[
'testt.title as title'
]
);
//$this->printlogquery(true);
//return $obj;
}
}