Now let’s come back to frontend development. Earlier we created a controller where I wrote a die statement to show you that the controller is working. But in the real world, we have to show HTML content.
To show HTML content we use .phtml files. These .phtml files are called template files. To map the controller with .phtml files we use layout files. The layout files are of .xml type. As all of these are related to viewing the page. So it makes sense to put them in a different folder, which is called the view folder.
First we need to modify the controller file, Controller/Manage/Add.php
Here we are using \Magento\Framework\View\Result\PageFactory class to initialize the layout. With this we can configure the page, here we have set the Title of the page. And after calling the getLayout() method to process the layout file, we have returned the result page.
Layout
Now if you notice we have not explicitly mentioned the layout file name in the controller. So Magento will look for the layout file with the name routerId_controllerName_actionName.xml . If we want then we can explicitly give like,
For the layout file, we need to create view/frontend/layout folder under the module directory. In the layout folder, we need to create a layout file with name blogmanager_manage_add.xml . If you remembered we used blogmanager as our router id. It’s common practice to use routerId as same as frontName because then the layout file name will be similar to the URL.
As you can see in the page tag we have used the layout attribute with the value 1column. Magento supports different types of layouts such as,
i) 1coumn
ii) 2columns-left
iii) 2columns-right
iv) 3columns
The body node refers that we are modifying contents within the body tag of the html. The page layout in magento is made out of multiple containers. And the container can have nested containers. The inner most containers have blocks in them and each block can have child blocks.
For simplicity, you can think of the header, footer, and main content as individual containers. However, Magento’s layout structure is much more complex, which helps us to modify any component. For the 2columns-left layout, the main content will have two sub-containers, one for content and another on the left side as a sidebar container.
With the referenceContainer tag, we can target any container, here we are targeting the main container whose name is content. You can find more container and block names in vendor/magento/module-theme/view/frontend/layout/default.xml file.
Inside the container, we are calling our phtml file with a block tag. Here we are using the default template block class Magento\Framework\View\Element\Template but we can create our own block class if we have to pass some data into the phtml. We will see more about the Block class in the next blog. The block tag has a name attribute, we can use any sensible name here to identify that block.
Templates
The interesting part in the block tag is template=”Webkul_BlogManager::add.phtml”, this represents the path of the template file. The first part of :: is the module name and the second part is the path in reference to the view/frontend/templates folder. As in the path we have given the phtml file name so we can directly create add.phtml file under the view/frontend/templates folder.
After writing all of this code we have to run the di compile command. And now if you browse the URL you will see the page,
Please try out different layout types on your own.
If you make some changes in the template file and can not find it when reloading the page then please flush the cache.
We are aiming to create a blog portal where customers can write blogs. So it make much more sense that the page should appear like other customer account pages and instead of manually entering the url we should have a menu in the customer navigation.
To add the customer navigation menu we will follow “Magento2 – Add New Link in My Account Navigation Panel” blog. We have to create a customer_account.xml file under the view/frontend/layout folder. Magento already has this XML file we are just appending our code to it.
Now let’s modify the blogmanager_manage_add.xml file to match the customer account pages structure.
Here you can see that we have removed the layout type and added the <update handle=”customer_account”/> tag. Basically, it says that copies everything from the customer_account.xml, so it will copy all the structure from customer_account.xml which acts as a base for every customer account-related page.
Now when we di compile and reload we will see something like,
Folder structure till now,
PS. Please run the di compile command if you create a new file, modify any .xml file, or make changes in the constructor of a class. Sometimes running di compile might not have any effect then we should explicitly remove the generated/code folder by running rm -rf generated/code from the Magento root directory.