In this blog we will show the published and approved blogs on front-end. This will be our first public page since all of the pages before it required some kind of authentication either customer or admin. That means guest user also will be able to access this page.
The url for the blog listing page will be http://hostname/blog . For now you will have to directly browse the page. But in next blog we will add menus for this page.
So let’s create the controller file, Controller/Index/Index.php
<?php
namespace Webkul\BlogManager\Controller\Index;
use Magento\Framework\App\Action\Context;
use Magento\Framework\View\Result\PageFactory;
class Index extends \Magento\Framework\App\Action\Action
One thing to note here is that we have extended \Magento\Framework\App\Action\Action and not the customer abstract account. That’s because this page will be accessible to guest users also.
Now the next step is to create the layout file view/frontend/layout/blogmanager_index_index.xml
Note here we have used layout=”1column” instead of the 2 column layout pattern. Also we have not used the update handle code here because that was required to load base structure of customer account pages. And we have added the css node which will load the style file.
Let’s create the template file now view/frontend/templates/published/list.phtml
We have loaded all the blogs with getCollection method, which we will create in block. Then we have looped over each blog to show data about them.
We have added links to view blog page which we will create in next blogs. Also we have used getFormattedDate and getAuthor which we will create in block. We have displayed first 100 characters of blog content.
Also we have called getPagerHtml to get the pagination when we have lots of blogs.
Now let’s see the block class Block/Published/BlogList.php
<?php
namespace Webkul\BlogManager\Block\Published;
class BlogList extends \Magento\Framework\View\Element\Template
There are multiple things to notice here. First we have loaded the blogs based on status and sorted them by created date in getCollection method. After loading it we have set the collection in $this->blogList field variable. if (!$this->blogList) this ensure that we load the collection only once for a page load. Because if you see we have called the getCollection multiple times in _prepareLayout and also in the template file. So it will ensure that we load the collection only once and save the data for future function calls.
We need the _prepareLayout function so that the pagination works. Because we have not created code for pager but used magento’s pagination.
In getPagerHtml we have called for an child html called pager. This will be responsible for showing the pager based on the collection that we provide in prepare layout function.
The getAuthor is used to get the author name based on the id. We have loaded the customer model and get the name. If the id is 0 or if the customer with that id does not exist then it will return ‘Admin’.
For formatting dates I have created a function getFormattedDate which again calls a function of same from helper. We will create this function in helper.
Now let’s edit the helper class Helper/Data.php
<?php
namespace Webkul\BlogManager\Helper;
use Magento\Customer\Model\Session;
class Data extends \Magento\Framework\App\Helper\AbstractHelper