tkotosz / block-decorator-magento2
Tkotosz - Block Decorator module for Magento 2
Installs: 24 373
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 1
Forks: 0
Open Issues: 0
Type:magento2-module
Requires
- php: >=7.1
- magento/framework: ^100.1|^101.0|^102.0
- magento/module-catalog: ^101.0|^102.0|^103.0
This package is auto-updated.
Last update: 2024-10-19 02:06:42 UTC
README
This module allows it to decorate Blocks used in the layout with extra data based on interfaces implemented by the blocks.
Installation
Install by adding to your composer.json
:
composer require tkotosz/block-decorator-magento2
How it works?
The module registers an "after plugin" for the Magento\Framework\View\Element\BlockFactory
which used by Magento to instantiate Blocks. In this plugin the block object created by the factory passed over to all registered decorators to decorate the block with extra data if needed. Each decorator is responsible for checking the type of the block and decide whether it needs to do anything.
How to use?
-
Create an interface which can be implemented by any block to get a specific data. (example:
Tkotosz\BlockDecorator\View\Element\Block\CurrentProduct\ProductNameAwareInterface
) -
Create your block class in the same way as you do it normally and implement your interface created in the 1st step. (example:
Tkotosz\BlockDecorator\Block\Product\View\ProductName
) -
Create your own decorator which can decorate the blocks with the required data when applicable (when your interface is implemented by the block). To create a the decorator you just need to create a new class which implements the
Tkotosz\BlockDecorator\View\Element\Block\Decorator\DecoratorInterface
. (example:Tkotosz\BlockDecorator\View\Element\Block\Decorator\CurrentProductName
) -
Register your decorator in the Magento di like this:
<type name="Tkotosz\BlockDecorator\View\Element\Block\Decorator\Container">
<arguments>
<argument xsi:type="array" name="decorators">
<item name="your_awesome_decorator" xsi:type="object">Your\Awesome\Decorator</item>
</argument>
</arguments>
</type>
(example: see how Tkotosz\BlockDecorator\View\Element\Block\Decorator\CurrentProductName
is registered in the src/etc/di.xml
)
- Add your new block to any layout, when the block is instantiated your decorator will run to set the required data, which later can be used when the block is rendered.