{"id":871,"date":"2023-11-24T18:49:50","date_gmt":"2023-11-24T13:19:50","guid":{"rendered":"https:\/\/magecurious.com\/blog\/?p=871"},"modified":"2025-01-28T13:45:48","modified_gmt":"2025-01-28T08:15:48","slug":"how-to-create-ui-component-grid-in-magento-2","status":"publish","type":"post","link":"https:\/\/magecurious.com\/blog\/how-to-create-ui-component-grid-in-magento-2\/","title":{"rendered":"How To Create UI Component Grid in Magento 2"},"content":{"rendered":"\n<p>Hello Everyone,<\/p>\n\n\n\n<p>In this blog, we will learn about how to Create UI Component Grid in Magento 2.<\/p>\n\n\n\n<p>Magento 2 grid is a way to list items in a database table.<\/p>\n\n\n\n<p>Magento 2 gives grids like order grid, product grid etc. but still sometimes we are required to create a new custom admin grid.<\/p>\n\n\n\n<p>Without wasting your time, let us guide you straight away. Follow the easy step given below to Create UI Component Grid in Magento 2.<\/p>\n\n\n\n<p><strong>STEPS FOR CREATE UI COMPONENT GRID IN MAGENTO 2<\/strong><\/p>\n\n\n\n<p><strong>Step 1: Create di.xml file<\/strong><\/p>\n\n\n\n<p>In the below code we set the main table name as &#8220;magecurious_custom_table&#8221;, you can change it as per your table name.<\/p>\n\n\n<div class=\"wp-block-syntaxhighlighter-code \"><pre class=\"brush: plain; title: ; notranslate\" title=\"\">\napp\/code\/Vendor\/Extension\/etc\/di.xml\n\n&amp;lt;?xml version=&quot;1.0&quot;?&gt;\n&amp;lt;config xmlns:xsi=&quot;http:\/\/www.w3.org\/2001\/XMLSchema-instance&quot; xsi:noNamespaceSchemaLocation=&quot;urn:magento:framework:ObjectManager\/etc\/config.xsd&quot;&gt;\n    &amp;lt;type name=&quot;Magento\\Framework\\View\\Element\\UiComponent\\DataProvider\\CollectionFactory&quot;&gt;\n        &amp;lt;arguments&gt;\n            &amp;lt;argument name=&quot;collections&quot; xsi:type=&quot;array&quot;&gt;\n                &amp;lt;item name=&quot;ui_listing_data_source&quot; xsi:type=&quot;string&quot;&gt;Vendor\\Extension\\Model\\ResourceModel\\BookInfo\n\\Grid\\Collection&amp;lt;\/item&gt;\n            &amp;lt;\/argument&gt;\n        &amp;lt;\/arguments&gt;\n    &amp;lt;\/type&gt;\n    &amp;lt;virtualType name=&quot;Vendor\\Extension\\Model\\ResourceModel\\BookInfo\\Grid\\Collection&quot; type=&quot;Magento\\Framework\\View\\Element\\UiComponent\\DataProvider\\SearchResult&quot;&gt;\n        &amp;lt;arguments&gt;\n            &amp;lt;argument name=&quot;mainTable&quot; xsi:type=&quot;string&quot;&gt;magecurious_custom_table&amp;lt;\/argument&gt;\n            &amp;lt;argument name=&quot;resourceModel&quot; xsi:type=&quot;string&quot;&gt;Vendor\\Extension\\Model\\ResourceModel\\BookInfo&amp;lt;\/argument&gt;\n        &amp;lt;\/arguments&gt;\n    &amp;lt;\/virtualType&gt;\n&amp;lt;\/config&gt;\n<\/pre><\/div>\n\n\n<p><strong>Step 2: Create Collection.php file<\/strong><\/p>\n\n\n\n<p>We already created Model, Resource Model and Collection of BookInfo in our previous blog so now here we create a collection file for grid.<\/p>\n\n\n<div class=\"wp-block-syntaxhighlighter-code \"><pre class=\"brush: plain; title: ; notranslate\" title=\"\">\n\n<\/pre><\/div>\n\n<div class=\"wp-block-syntaxhighlighter-code \"><pre class=\"brush: plain; title: ; notranslate\" title=\"\">\napp\/code\/Vendor\/Extension\/Model\/ResourceModel\/BookInfo\/Grid\/Collection.php\n\n&amp;lt;?php\n\nnamespace Vendor\\Extension\\Model\\ResourceModel\\BookInfo\\Grid;\n\nuse Vendor\\Extension\\Model\\ResourceModel\\BookInfo\\Collection as BookInfoCollection;\nuse Magento\\Framework\\View\\Element\\UiComponent\\DataProvider\\Document as BookInfoModel;\n\nclass Collection extends BookInfoCollection implements \\Magento\\Framework\\Api\\Search\\SearchResultInterface\n{\n    protected $aggregations;\n\n    \/\/ @codingStandardsIgnoreStart\n    public function __construct(\n        \\Magento\\Framework\\Data\\Collection\\EntityFactoryInterface $entityFactory,\n        \\Psr\\Log\\LoggerInterface $logger,\n        \\Magento\\Framework\\Data\\Collection\\Db\\FetchStrategyInterface $fetchStrategy,\n        \\Magento\\Framework\\Event\\ManagerInterface $eventManager,\n        $mainTable,\n        $eventPrefix,\n        $eventObject,\n        $resourceModel,\n        $model = BookInfoModel::class,\n        $connection = null,\n        \\Magento\\Framework\\Model\\ResourceModel\\Db\\AbstractDb $resource = null\n    ) {\n        parent::__construct($entityFactory, $logger, $fetchStrategy, $eventManager, $connection, $resource);\n        $this-&gt;_eventPrefix = $eventPrefix;\n        $this-&gt;_eventObject = $eventObject;\n        $this-&gt;_init($model, $resourceModel);\n        $this-&gt;setMainTable($mainTable);\n    }\n    \/\/ @codingStandardsIgnoreEnd\n\n    public function getAggregations()\n    {\n        return $this-&gt;aggregations;\n    }\n    public function setAggregations($aggregations)\n    {\n        $this-&gt;aggregations = $aggregations;\n    }\n    public function getAllIds($limit = null, $offset = null)\n    {\n        return $this-&gt;getConnection()-&gt;fetchCol($this-&gt;_getAllIdsSelect($limit, $offset), $this-&gt;_bindParams);\n    }\n    public function getSearchCriteria()\n    {\n        return null;\n    }\n    public function setSearchCriteria(\\Magento\\Framework\\Api\\SearchCriteriaInterface $searchCriteria = null)\n    {\n        return $this;\n    }\n    public function getTotalCount()\n    {\n        return $this-&gt;getSize();\n    }\n    public function setTotalCount($totalCount)\n    {\n        return $this;\n    }\n    public function setItems(array $items = null)\n    {\n        return $this;\n    }\n}\n<\/pre><\/div>\n\n\n<p><strong>Step 3: Create helloworld_index_index.xml file<\/strong><\/p>\n\n\n\n<p>This file is used to create a ui component grid.<\/p>\n\n\n<div class=\"wp-block-syntaxhighlighter-code \"><pre class=\"brush: plain; title: ; notranslate\" title=\"\">\napp\/code\/Vendor\/Extension\/view\/adminhtml\/layout\/helloworld_index_index.xml\n\n&amp;lt;?xml version=&quot;1.0&quot;?&gt;\n&amp;lt;page xmlns:xsi=&quot;http:\/\/www.w3.org\/2001\/XMLSchema-instance&quot; xsi:noNamespaceSchemaLocation=&quot;..\/..\/..\/..\/..\/..\/..\/lib\/internal\/Magento\/Framework\/View\/Layout\/etc\/page_configuration.xsd&quot;&gt;\n    &amp;lt;update handle=&quot;styles&quot;\/&gt;\n    &amp;lt;body&gt;\n        &amp;lt;referenceContainer name=&quot;content&quot;&gt;\n        \t&amp;lt;uiComponent name=&quot;ui_listing&quot;\/&gt;\n        &amp;lt;\/referenceContainer&gt;\n    &amp;lt;\/body&gt;\n&amp;lt;\/page&gt;\n<\/pre><\/div>\n\n\n<p><strong>Step 4: Create Index.php file<\/strong>.<\/p>\n\n\n\n<p>In the code below we can set the title &#8220;manage grid&#8221;, you can change what you want. This controller is used to render the layout of the grid.<\/p>\n\n\n<div class=\"wp-block-syntaxhighlighter-code \"><pre class=\"brush: plain; title: ; notranslate\" title=\"\">\napp\/code\/Vendor\/Extension\/Controller\/Adminhtml\/Index\/Index.php\n\n&amp;lt;?php\n\nnamespace Vendor\\Extension\\Controller\\Adminhtml\\Index;\n\nuse Magento\\Backend\\App\\Action;\nuse Magento\\Backend\\App\\Action\\Context;\nuse Magento\\Framework\\Controller\\ResultFactory;\nuse Magento\\Framework\\View\\Result\\PageFactory;\n\nclass Index extends Action\n{\n    protected $resultPageFactory;\n\n    public function __construct(\n        Context $context,\n        PageFactory $resultPageFactory\n    ) {\n        parent::__construct($context);\n        $this-&gt;resultPageFactory = $resultPageFactory;\n    }\n    public function execute()\n    {\n        $resultRedirect = $this-&gt;resultFactory-&gt;create(ResultFactory::TYPE_REDIRECT);\n        $resultPage = $this-&gt;resultPageFactory-&gt;create();\n        $resultPage-&gt;getConfig()-&gt;getTitle()-&gt;set(__(&#039;Manage Grid&#039;));\n        return $resultPage;\n    }\n}\n<\/pre><\/div>\n\n\n<p><strong>Step 5: Create ui_listing.xml file<\/strong><\/p>\n\n\n\n<p>In below code we can add filters, Add new Record Button, database column fields, edit\/delete actions.<\/p>\n\n\n\n<p>You can add as many database column fields as you want.<\/p>\n\n\n<div class=\"wp-block-syntaxhighlighter-code \"><pre class=\"brush: plain; title: ; notranslate\" title=\"\">\napp\/code\/Vendor\/Extension\/view\/adminhtml\/ui_component\/ui_listing.xml\n\n&amp;lt;listing xmlns:xsi=&quot;http:\/\/www.w3.org\/2001\/XMLSchema-instance&quot; xsi:noNamespaceSchemaLocation=&quot;urn:magento:module:Magento_Ui:etc\/ui_configuration.xsd&quot;&gt;\n    &amp;lt;argument name=&quot;data&quot; xsi:type=&quot;array&quot;&gt;\n        &amp;lt;item name=&quot;js_config&quot; xsi:type=&quot;array&quot;&gt;\n            &amp;lt;item name=&quot;provider&quot; xsi:type=&quot;string&quot;&gt;ui_listing.ui_listing_data_source&amp;lt;\/item&gt;\n            &amp;lt;item name=&quot;deps&quot; xsi:type=&quot;string&quot;&gt;ui_listing.ui_listing_data_source&amp;lt;\/item&gt;\n        &amp;lt;\/item&gt;\n        &amp;lt;item name=&quot;spinner&quot; xsi:type=&quot;string&quot;&gt;columns&amp;lt;\/item&gt;\n        &amp;lt;item name=&quot;buttons&quot; xsi:type=&quot;array&quot;&gt;\n            &amp;lt;item name=&quot;add&quot; xsi:type=&quot;array&quot;&gt;\n                &amp;lt;item name=&quot;name&quot; xsi:type=&quot;string&quot;&gt;add&amp;lt;\/item&gt;\n                &amp;lt;item name=&quot;label&quot; xsi:type=&quot;string&quot; translate=&quot;true&quot;&gt;Add New Record&amp;lt;\/item&gt;\n                &amp;lt;item name=&quot;class&quot; xsi:type=&quot;string&quot;&gt;primary&amp;lt;\/item&gt;\n                &amp;lt;item name=&quot;url&quot; xsi:type=&quot;string&quot;&gt;*\/*\/form&amp;lt;\/item&gt;\n            &amp;lt;\/item&gt;\n        &amp;lt;\/item&gt;\n    &amp;lt;\/argument&gt;\n    &amp;lt;dataSource name=&quot;ui_listing_data_source&quot;&gt;\n        &amp;lt;argument name=&quot;dataProvider&quot; xsi:type=&quot;configurableObject&quot;&gt;\n            &amp;lt;argument name=&quot;class&quot; xsi:type=&quot;string&quot;&gt;Magento\\Framework\\View\\Element\\UiComponent\\DataProvider\\DataProvider&amp;lt;\/argument&gt;\n            &amp;lt;argument name=&quot;name&quot; xsi:type=&quot;string&quot;&gt;ui_listing_data_source&amp;lt;\/argument&gt;\n            &amp;lt;argument name=&quot;primaryFieldName&quot; xsi:type=&quot;string&quot;&gt;id&amp;lt;\/argument&gt;\n            &amp;lt;argument name=&quot;requestFieldName&quot; xsi:type=&quot;string&quot;&gt;id&amp;lt;\/argument&gt;\n            &amp;lt;argument name=&quot;data&quot; xsi:type=&quot;array&quot;&gt;\n                &amp;lt;item name=&quot;config&quot; xsi:type=&quot;array&quot;&gt;\n                    &amp;lt;item name=&quot;component&quot; xsi:type=&quot;string&quot;&gt;Magento_Ui\/js\/grid\/provider&amp;lt;\/item&gt;\n                    &amp;lt;item name=&quot;update_url&quot; xsi:type=&quot;url&quot; path=&quot;mui\/index\/render&quot; \/&gt;\n                    &amp;lt;item name=&quot;storageConfig&quot; xsi:type=&quot;array&quot;&gt;\n                        &amp;lt;item name=&quot;indexField&quot; xsi:type=&quot;string&quot;&gt;id&amp;lt;\/item&gt;\n                    &amp;lt;\/item&gt;\n                &amp;lt;\/item&gt;\n            &amp;lt;\/argument&gt;\n        &amp;lt;\/argument&gt;\n    &amp;lt;\/dataSource&gt;\n    &amp;lt;listing&gt;\n        &amp;lt;listingToolbar&gt;\n            &amp;lt;bookmark name=&quot;bookmarks&quot; \/&gt;\n            &amp;lt;columnsControls name=&quot;columns_controls&quot; \/&gt;\n            &amp;lt;filters&gt;\n                &amp;lt;argument name=&quot;data&quot; xsi:type=&quot;array&quot;&gt;\n                    &amp;lt;item name=&quot;config&quot; xsi:type=&quot;array&quot;&gt;\n                        &amp;lt;item name=&quot;applied&quot; xsi:type=&quot;array&quot;&gt;\n                            &amp;lt;item name=&quot;is_approved&quot; xsi:type=&quot;string&quot;&gt;1&amp;lt;\/item&gt;\n                        &amp;lt;\/item&gt;\n                    &amp;lt;\/item&gt;\n                &amp;lt;\/argument&gt;\n            &amp;lt;\/filters&gt;\n            &amp;lt;paging name=&quot;listing_paging&quot; \/&gt;\n        &amp;lt;\/listingToolbar&gt;\n    &amp;lt;\/listing&gt;\n    &amp;lt;columns name=&quot;columns&quot;&gt;\n        &amp;lt;argument name=&quot;data&quot; xsi:type=&quot;array&quot;&gt;\n            &amp;lt;item name=&quot;config&quot; xsi:type=&quot;array&quot;&gt;\n                &amp;lt;item name=&quot;resizeConfig&quot; xsi:type=&quot;array&quot;&gt;\n                    &amp;lt;item name=&quot;enabled&quot; xsi:type=&quot;boolean&quot;&gt;false&amp;lt;\/item&gt;\n                &amp;lt;\/item&gt;\n            &amp;lt;\/item&gt;\n        &amp;lt;\/argument&gt;\n        &amp;lt;settings&gt;\n            &amp;lt;childDefaults&gt;\n                &amp;lt;param name=&quot;fieldAction&quot; xsi:type=&quot;array&quot;&gt;\n                &amp;lt;item name=&quot;provider&quot; xsi:type=&quot;string&quot;&gt;ui_listing.ui_listing.columns.actions&amp;lt;\/item&gt;\n                &amp;lt;item name=&quot;target&quot; xsi:type=&quot;string&quot;&gt;applyAction&amp;lt;\/item&gt;\n                &amp;lt;item name=&quot;params&quot; xsi:type=&quot;array&quot;&gt;\n                    &amp;lt;item name=&quot;0&quot; xsi:type=&quot;string&quot;&gt;edit&amp;lt;\/item&gt;\n                    &amp;lt;item name=&quot;1&quot; xsi:type=&quot;string&quot;&gt;${ $.$data.rowIndex }&amp;lt;\/item&gt;\n                &amp;lt;\/item&gt;\n                &amp;lt;\/param&gt;\n            &amp;lt;\/childDefaults&gt;\n        &amp;lt;\/settings&gt;\n        &amp;lt;selectionsColumn name=&quot;ids&quot;&gt;\n            &amp;lt;argument name=&quot;data&quot; xsi:type=&quot;array&quot;&gt;\n                &amp;lt;item name=&quot;config&quot; xsi:type=&quot;array&quot;&gt;\n                    &amp;lt;item name=&quot;resizeEnabled&quot; xsi:type=&quot;boolean&quot;&gt;false&amp;lt;\/item&gt;\n                    &amp;lt;item name=&quot;resizeDefaultWidth&quot; xsi:type=&quot;string&quot;&gt;55&amp;lt;\/item&gt;\n                    &amp;lt;item name=&quot;indexField&quot; xsi:type=&quot;string&quot;&gt;id&amp;lt;\/item&gt;\n                &amp;lt;\/item&gt;\n            &amp;lt;\/argument&gt;\n        &amp;lt;\/selectionsColumn&gt;\n        &amp;lt;column name=&quot;id&quot;&gt;\n            &amp;lt;argument name=&quot;data&quot; xsi:type=&quot;array&quot;&gt;\n                &amp;lt;item name=&quot;config&quot; xsi:type=&quot;array&quot;&gt;\n                    &amp;lt;item name=&quot;resizeEnabled&quot; xsi:type=&quot;boolean&quot;&gt;false&amp;lt;\/item&gt;\n                    &amp;lt;item name=&quot;resizeDefaultWidth&quot; xsi:type=&quot;string&quot;&gt;55&amp;lt;\/item&gt;\n                    &amp;lt;item name=&quot;filter&quot; xsi:type=&quot;string&quot;&gt;textRange&amp;lt;\/item&gt;\n                    &amp;lt;item name=&quot;sorting&quot; xsi:type=&quot;string&quot;&gt;asc&amp;lt;\/item&gt;\n                    &amp;lt;item name=&quot;label&quot; xsi:type=&quot;string&quot; translate=&quot;true&quot;&gt;ID&amp;lt;\/item&gt;\n                &amp;lt;\/item&gt;\n            &amp;lt;\/argument&gt;\n        &amp;lt;\/column&gt;\n        &amp;lt;column name=&quot;field_1&quot;&gt;\n            &amp;lt;argument name=&quot;data&quot; xsi:type=&quot;array&quot;&gt;\n                &amp;lt;item name=&quot;config&quot; xsi:type=&quot;array&quot;&gt;\n                    &amp;lt;item name=&quot;filter&quot; xsi:type=&quot;string&quot;&gt;text&amp;lt;\/item&gt;\n                    &amp;lt;item name=&quot;label&quot; xsi:type=&quot;string&quot; translate=&quot;true&quot;&gt;Field 1&amp;lt;\/item&gt;\n                &amp;lt;\/item&gt;\n            &amp;lt;\/argument&gt;\n        &amp;lt;\/column&gt;\n        &amp;lt;column name=&quot;field_2&quot;&gt;\n            &amp;lt;argument name=&quot;data&quot; xsi:type=&quot;array&quot;&gt;\n                &amp;lt;item name=&quot;config&quot; xsi:type=&quot;array&quot;&gt;\n                    &amp;lt;item name=&quot;filter&quot; xsi:type=&quot;string&quot;&gt;text&amp;lt;\/item&gt;\n                    &amp;lt;item name=&quot;label&quot; xsi:type=&quot;string&quot; translate=&quot;true&quot;&gt;Field 2&amp;lt;\/item&gt;\n                &amp;lt;\/item&gt;\n            &amp;lt;\/argument&gt;\n        &amp;lt;\/column&gt;\n        &amp;lt;actionsColumn name=&quot;actions&quot; class=&quot;Vendor\\Extension\\Ui\\Component\\Column\\Actions&quot;&gt;\n            &amp;lt;argument name=&quot;data&quot; xsi:type=&quot;array&quot;&gt;\n                &amp;lt;item name=&quot;config&quot; xsi:type=&quot;array&quot;&gt;\n                    &amp;lt;item name=&quot;indexField&quot; xsi:type=&quot;string&quot;&gt;id&amp;lt;\/item&gt;\n                &amp;lt;\/item&gt;\n            &amp;lt;\/argument&gt;\n        &amp;lt;\/actionsColumn&gt;\n    &amp;lt;\/columns&gt;\n&amp;lt;\/listing&gt;\n<\/pre><\/div>\n\n\n<p><strong>Step 6: Create Actions.php file<\/strong><\/p>\n\n\n<div class=\"wp-block-syntaxhighlighter-code \"><pre class=\"brush: plain; title: ; notranslate\" title=\"\">\napp\/code\/Vendor\/Extension\/Ui\/Component\/Column\/Actions.php\n\n&amp;lt;?php\n\nnamespace Vendor\\Extension\\Ui\\Component\\Column;\n\nuse Magento\\Framework\\UrlInterface;\nuse Magento\\Framework\\View\\Element\\UiComponentFactory;\nuse Magento\\Framework\\View\\Element\\UiComponent\\ContextInterface;\nuse Magento\\Ui\\Component\\Listing\\Columns\\Column;\n\nclass Actions extends Column\n{\n\n    const URL_PATH_EDIT = &#039;helloworld\/index\/form&#039;;\n    const URL_PATH_DELETE = &#039;helloworld\/index\/delete&#039;;\n\n    protected $urlBuilder;\n\n    public function __construct(\n        ContextInterface $context,\n        ComponentFactory $BookInfoFactory,\n        UrlInterface $urlBuilder,\n        array $components = &#x5B;],\n        array $data = &#x5B;]\n    ) {\n        $this-&gt;urlBuilder = $urlBuilder;\n        parent::__construct($context, $BookInfoFactory, $components, $data);\n    }\n\n    public function prepareDataSource(array $dataSource)\n    {\n        if (isset($dataSource&#x5B;&#039;data&#039;]&#x5B;&#039;items&#039;])) {\n            foreach ($dataSource&#x5B;&#039;data&#039;]&#x5B;&#039;items&#039;] as &amp;amp;$item) {\n                if (isset($item&#x5B;&#039;id&#039;])) {\n                    $item&#x5B;$this-&gt;getData(&#039;name&#039;)] = &#x5B;\n                        &#039;edit&#039; =&gt; &#x5B;\n                            &#039;href&#039; =&gt; $this-&gt;urlBuilder-&gt;getUrl(\n                                static::URL_PATH_EDIT,\n                                &#x5B;\n                                    &#039;id&#039; =&gt; $item&#x5B;&#039;id&#039;],\n                                ]\n                            ),\n                            &#039;label&#039; =&gt; __(&#039;Edit&#039;),\n                        ],\n                        &#039;delete&#039; =&gt; &#x5B;\n                            &#039;href&#039; =&gt; $this-&gt;urlBuilder-&gt;getUrl(\n                                static::URL_PATH_DELETE,\n                                &#x5B;\n                                    &#039;id&#039; =&gt; $item&#x5B;&#039;id&#039;],\n                                ]\n                            ),\n                            &#039;label&#039; =&gt; __(&#039;Delete&#039;),\n                            &#039;confirm&#039; =&gt; &#x5B;\n                                &#039;title&#039; =&gt; __(&#039;Delete Record ?&#039;),\n                                &#039;message&#039; =&gt; __(&#039;Are you sure you wan\\&#039;t to delete a record?&#039;),\n                            ],\n                        ],\n                    ];\n                }\n            }\n        }\n\n        return $dataSource;\n    }\n}\n<\/pre><\/div>\n\n\n<p><strong>Step 7: Create Delete.php file<\/strong><\/p>\n\n\n\n<p>Here we can only create delete action full form action will be created in our next blog.<\/p>\n\n\n<div class=\"wp-block-syntaxhighlighter-code \"><pre class=\"brush: plain; title: ; notranslate\" title=\"\">\napp\/code\/Vendor\/Extension\/Controller\/Adminhtml\/Index\/Delete.php\n\n&amp;lt;?php\n\nnamespace Vendor\\Extension\\Controller\\Adminhtml\\Index;\n\nuse Vendor\\Extension\\Model\\BookInfoFactory;\nuse Magento\\Backend\\App\\Action;\nuse Magento\\Backend\\App\\Action\\Context;\nuse Magento\\Framework\\View\\Result\\PageFactory;\n\nclass Delete extends Action\n{\n    protected $resultPageFactory;\n    protected $BookInfoFactory;\n\n    public function __construct(\n        Context $context,\n        PageFactory $resultPageFactory,\n        BookInfoFactory $BookInfoFactory\n    ) {\n        $this-&gt;resultPageFactory = $resultPageFactory;\n        $this-&gt;BookInfoFactory = $BookInfoFactory;\n        parent::__construct($context);\n    }\n\n    public function execute()\n    {\n        $resultRedirectFactory = $this-&gt;resultRedirectFactory-&gt;create();\n        try {\n            $id = $this-&gt;getRequest()-&gt;getParam(&#039;id&#039;);\n            if ($id) {\n                $model = $this-&gt;BookInfoFactory-&gt;create()-&gt;load($id);\n                if ($model-&gt;getId()) {\n                    $model-&gt;delete();\n                    $this-&gt;messageManager-&gt;addSuccessMessage(__(&quot;Record Delete Successfully.&quot;));\n                } else {\n                    $this-&gt;messageManager-&gt;addErrorMessage(__(&quot;Something went wrong, Please try again.&quot;));\n                }\n            } else {\n                $this-&gt;messageManager-&gt;addErrorMessage(__(&quot;Something went wrong, Please try again.&quot;));\n            }\n        } catch (\\Exception $e) {\n            $this-&gt;messageManager-&gt;addErrorMessage($e, __(&quot;We can&#039;t delete record, Please try again.&quot;));\n        }\n        return $resultRedirectFactory-&gt;setPath(&#039;*\/*\/index&#039;);\n    }\n}\n<\/pre><\/div>\n\n\n<p><strong>Step 8: Finally run the below commands<\/strong><\/p>\n\n\n\n<p>$ php bin\/magento setup:upgrade<\/p>\n\n\n\n<p>$ php bin\/magento cache:clean<\/p>\n\n\n\n<p>$ php bin\/magento cache:flush<\/p>\n\n\n\n<p><strong>Step 8: Output:<\/strong><\/p>\n\n\n\n<figure class=\"wp-block-image\"><img decoding=\"async\" src=\"https:\/\/lh7-us.googleusercontent.com\/ZrpwwBOtuW9NqTgUUcmCllgqZhyIl1AcdsMpXYd-eubhHH5Yra7Ynr8xwJhGGFbkXG8IqIcb2v7KTOICrV7c2XUO0fGjn_OZfYIFJn41-XH__2CX_IY75WzGBNPs9I-b_bLQiN_V3UjOCKsj6Q5SGS8\" alt=\"\"\/><\/figure>\n\n\n\n<div style=\"height:21px\" aria-hidden=\"true\" class=\"wp-block-spacer\"><\/div>\n\n\n\n<p><strong>Final Thoughts:<\/strong><\/p>\n\n\n\n<p>So this was the easiest way which we have told you in this blog. This is how you can Create UI Component Grid in Magento 2. Hope you liked the blog.<\/p>\n\n\n\n<p>So quickly go to the comment box and tell me how you like this blog?<\/p>\n\n\n\n<p><strong>Stay tuned with us on our site to get new updates of Magento.<\/strong><\/p>\n\n\n\n<p>Thanks for reading and visiting our site.<\/p>\n\n\n<!-- FeedbackWP Plugin --><div  class=\"rmp-widgets-container rmp-wp-plugin rmp-main-container js-rmp-widgets-container js-rmp-widgets-container--871 \"  data-post-id=\"871\">    <!-- Rating widget -->  <div class=\"rmp-rating-widget js-rmp-rating-widget\">          <p class=\"rmp-heading rmp-heading--title\">        How useful was this post?      <\/p>              <p class=\"rmp-heading rmp-heading--subtitle\">        Click on a star to rate it!      <\/p>        <div class=\"rmp-rating-widget__icons\">      <ul class=\"rmp-rating-widget__icons-list js-rmp-rating-icons-list\">                  <li class=\"rmp-rating-widget__icons-list__icon js-rmp-rating-item\" data-descriptive-rating=\"Not at all useful\" data-value=\"1\">              <i class=\"js-rmp-rating-icon rmp-icon rmp-icon--ratings rmp-icon--star \"><\/i>          <\/li>                  <li class=\"rmp-rating-widget__icons-list__icon js-rmp-rating-item\" data-descriptive-rating=\"Somewhat useful\" data-value=\"2\">              <i class=\"js-rmp-rating-icon rmp-icon rmp-icon--ratings rmp-icon--star \"><\/i>          <\/li>                  <li class=\"rmp-rating-widget__icons-list__icon js-rmp-rating-item\" data-descriptive-rating=\"Useful\" data-value=\"3\">              <i class=\"js-rmp-rating-icon rmp-icon rmp-icon--ratings rmp-icon--star \"><\/i>          <\/li>                  <li class=\"rmp-rating-widget__icons-list__icon js-rmp-rating-item\" data-descriptive-rating=\"Fairly useful\" data-value=\"4\">              <i class=\"js-rmp-rating-icon rmp-icon rmp-icon--ratings rmp-icon--star \"><\/i>          <\/li>                  <li class=\"rmp-rating-widget__icons-list__icon js-rmp-rating-item\" data-descriptive-rating=\"Very useful\" data-value=\"5\">              <i class=\"js-rmp-rating-icon rmp-icon rmp-icon--ratings rmp-icon--star \"><\/i>          <\/li>              <\/ul>    <\/div>    <p class=\"rmp-rating-widget__hover-text js-rmp-hover-text\"><\/p>        <button class=\"rmp-rating-widget__submit-btn rmp-btn js-submit-rating-btn\">      Submit Rating    <\/button>    <p class=\"rmp-rating-widget__results js-rmp-results rmp-rating-widget__results--hidden\">      Average rating <span class=\"rmp-rating-widget__results__rating js-rmp-avg-rating\">0<\/span> \/ 5. Vote count: <span class=\"rmp-rating-widget__results__votes js-rmp-vote-count\">0<\/span>    <\/p>    <p class=\"rmp-rating-widget__not-rated js-rmp-not-rated \">      No votes so far! Be the first to rate this post.    <\/p>    <p class=\"rmp-rating-widget__msg js-rmp-msg\"><\/p>  <\/div>  <!--Structured data -->        <\/div>\n","protected":false},"excerpt":{"rendered":"<p>Hello Everyone, In this blog, we will learn about how to Create UI Component Grid in Magento 2. Magento 2 grid is a way to list items in a database table. Magento 2 gives grids like order grid, product grid etc. but still sometimes we are required to create a new custom admin grid. Without [&hellip;]<\/p>\n","protected":false},"author":1,"featured_media":872,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"_jetpack_memberships_contains_paid_content":false,"footnotes":""},"categories":[4],"tags":[],"class_list":["post-871","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-magento-2"],"yoast_head":"<!-- This site is optimized with the Yoast SEO plugin v26.8 - https:\/\/yoast.com\/product\/yoast-seo-wordpress\/ -->\n<title>How To Create UI Component Grid in Magento 2 - Magecurious<\/title>\n<meta name=\"description\" content=\"Discover how to create a UI component grid in Magento 2 to enhance admin interfaces and improve data management.\" \/>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/magecurious.com\/blog\/how-to-create-ui-component-grid-in-magento-2\/\" \/>\n<meta property=\"og:locale\" content=\"en_US\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"How To Create UI Component Grid in Magento 2 - Magecurious\" \/>\n<meta property=\"og:description\" content=\"Discover how to create a UI component grid in Magento 2 to enhance admin interfaces and improve data management.\" \/>\n<meta property=\"og:url\" content=\"https:\/\/magecurious.com\/blog\/how-to-create-ui-component-grid-in-magento-2\/\" \/>\n<meta property=\"og:site_name\" content=\"Magecurious\" \/>\n<meta property=\"article:published_time\" content=\"2023-11-24T13:19:50+00:00\" \/>\n<meta property=\"article:modified_time\" content=\"2025-01-28T08:15:48+00:00\" \/>\n<meta property=\"og:image\" content=\"https:\/\/magecurious.com\/blog\/wp-content\/uploads\/2023\/11\/image_2023_11_24T12_37_42_448Z.png\" \/>\n\t<meta property=\"og:image:width\" content=\"1260\" \/>\n\t<meta property=\"og:image:height\" content=\"496\" \/>\n\t<meta property=\"og:image:type\" content=\"image\/png\" \/>\n<meta name=\"author\" content=\"Magecurious\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:label1\" content=\"Written by\" \/>\n\t<meta name=\"twitter:data1\" content=\"Magecurious\" \/>\n\t<meta name=\"twitter:label2\" content=\"Est. reading time\" \/>\n\t<meta name=\"twitter:data2\" content=\"2 minutes\" \/>\n<!-- \/ Yoast SEO plugin. -->","yoast_head_json":{"title":"How To Create UI Component Grid in Magento 2 - Magecurious","description":"Discover how to create a UI component grid in Magento 2 to enhance admin interfaces and improve data management.","robots":{"index":"index","follow":"follow","max-snippet":"max-snippet:-1","max-image-preview":"max-image-preview:large","max-video-preview":"max-video-preview:-1"},"canonical":"https:\/\/magecurious.com\/blog\/how-to-create-ui-component-grid-in-magento-2\/","og_locale":"en_US","og_type":"article","og_title":"How To Create UI Component Grid in Magento 2 - Magecurious","og_description":"Discover how to create a UI component grid in Magento 2 to enhance admin interfaces and improve data management.","og_url":"https:\/\/magecurious.com\/blog\/how-to-create-ui-component-grid-in-magento-2\/","og_site_name":"Magecurious","article_published_time":"2023-11-24T13:19:50+00:00","article_modified_time":"2025-01-28T08:15:48+00:00","og_image":[{"width":1260,"height":496,"url":"https:\/\/magecurious.com\/blog\/wp-content\/uploads\/2023\/11\/image_2023_11_24T12_37_42_448Z.png","type":"image\/png"}],"author":"Magecurious","twitter_card":"summary_large_image","twitter_misc":{"Written by":"Magecurious","Est. reading time":"2 minutes"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"Article","@id":"https:\/\/magecurious.com\/blog\/how-to-create-ui-component-grid-in-magento-2\/#article","isPartOf":{"@id":"https:\/\/magecurious.com\/blog\/how-to-create-ui-component-grid-in-magento-2\/"},"author":{"name":"Magecurious","@id":"https:\/\/magecurious.com\/blog\/#\/schema\/person\/6bced7da0991e7fbbd4550006a6494e2"},"headline":"How To Create UI Component Grid in Magento 2","datePublished":"2023-11-24T13:19:50+00:00","dateModified":"2025-01-28T08:15:48+00:00","mainEntityOfPage":{"@id":"https:\/\/magecurious.com\/blog\/how-to-create-ui-component-grid-in-magento-2\/"},"wordCount":349,"commentCount":0,"publisher":{"@id":"https:\/\/magecurious.com\/blog\/#organization"},"image":{"@id":"https:\/\/magecurious.com\/blog\/how-to-create-ui-component-grid-in-magento-2\/#primaryimage"},"thumbnailUrl":"https:\/\/magecurious.com\/blog\/wp-content\/uploads\/2023\/11\/image_2023_11_24T12_37_42_448Z.png","articleSection":["Magento 2 Blog"],"inLanguage":"en-US","potentialAction":[{"@type":"CommentAction","name":"Comment","target":["https:\/\/magecurious.com\/blog\/how-to-create-ui-component-grid-in-magento-2\/#respond"]}]},{"@type":"WebPage","@id":"https:\/\/magecurious.com\/blog\/how-to-create-ui-component-grid-in-magento-2\/","url":"https:\/\/magecurious.com\/blog\/how-to-create-ui-component-grid-in-magento-2\/","name":"How To Create UI Component Grid in Magento 2 - Magecurious","isPartOf":{"@id":"https:\/\/magecurious.com\/blog\/#website"},"primaryImageOfPage":{"@id":"https:\/\/magecurious.com\/blog\/how-to-create-ui-component-grid-in-magento-2\/#primaryimage"},"image":{"@id":"https:\/\/magecurious.com\/blog\/how-to-create-ui-component-grid-in-magento-2\/#primaryimage"},"thumbnailUrl":"https:\/\/magecurious.com\/blog\/wp-content\/uploads\/2023\/11\/image_2023_11_24T12_37_42_448Z.png","datePublished":"2023-11-24T13:19:50+00:00","dateModified":"2025-01-28T08:15:48+00:00","description":"Discover how to create a UI component grid in Magento 2 to enhance admin interfaces and improve data management.","breadcrumb":{"@id":"https:\/\/magecurious.com\/blog\/how-to-create-ui-component-grid-in-magento-2\/#breadcrumb"},"inLanguage":"en-US","potentialAction":[{"@type":"ReadAction","target":["https:\/\/magecurious.com\/blog\/how-to-create-ui-component-grid-in-magento-2\/"]}]},{"@type":"ImageObject","inLanguage":"en-US","@id":"https:\/\/magecurious.com\/blog\/how-to-create-ui-component-grid-in-magento-2\/#primaryimage","url":"https:\/\/magecurious.com\/blog\/wp-content\/uploads\/2023\/11\/image_2023_11_24T12_37_42_448Z.png","contentUrl":"https:\/\/magecurious.com\/blog\/wp-content\/uploads\/2023\/11\/image_2023_11_24T12_37_42_448Z.png","width":1260,"height":496},{"@type":"BreadcrumbList","@id":"https:\/\/magecurious.com\/blog\/how-to-create-ui-component-grid-in-magento-2\/#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"Home","item":"https:\/\/magecurious.com\/blog\/"},{"@type":"ListItem","position":2,"name":"How To Create UI Component Grid in Magento 2"}]},{"@type":"WebSite","@id":"https:\/\/magecurious.com\/blog\/#website","url":"https:\/\/magecurious.com\/blog\/","name":"Magecurious","description":"Blog","publisher":{"@id":"https:\/\/magecurious.com\/blog\/#organization"},"potentialAction":[{"@type":"SearchAction","target":{"@type":"EntryPoint","urlTemplate":"https:\/\/magecurious.com\/blog\/?s={search_term_string}"},"query-input":{"@type":"PropertyValueSpecification","valueRequired":true,"valueName":"search_term_string"}}],"inLanguage":"en-US"},{"@type":"Organization","@id":"https:\/\/magecurious.com\/blog\/#organization","name":"Magecurious","url":"https:\/\/magecurious.com\/blog\/","logo":{"@type":"ImageObject","inLanguage":"en-US","@id":"https:\/\/magecurious.com\/blog\/#\/schema\/logo\/image\/","url":"https:\/\/magecurious.com\/blog\/wp-content\/uploads\/2026\/03\/cropped-New_Project.png","contentUrl":"https:\/\/magecurious.com\/blog\/wp-content\/uploads\/2026\/03\/cropped-New_Project.png","width":596,"height":113,"caption":"Magecurious"},"image":{"@id":"https:\/\/magecurious.com\/blog\/#\/schema\/logo\/image\/"}},{"@type":"Person","@id":"https:\/\/magecurious.com\/blog\/#\/schema\/person\/6bced7da0991e7fbbd4550006a6494e2","name":"Magecurious","image":{"@type":"ImageObject","inLanguage":"en-US","@id":"https:\/\/magecurious.com\/blog\/#\/schema\/person\/image\/","url":"https:\/\/secure.gravatar.com\/avatar\/c9178df2190b2309da97c9f28dd475bc338275cf664d12678d7e5da51c761271?s=96&d=mm&r=g","contentUrl":"https:\/\/secure.gravatar.com\/avatar\/c9178df2190b2309da97c9f28dd475bc338275cf664d12678d7e5da51c761271?s=96&d=mm&r=g","caption":"Magecurious"},"sameAs":["https:\/\/magecurious.com"],"url":"https:\/\/magecurious.com\/blog\/author\/magecurious-wp\/"}]}},"jetpack_featured_media_url":"https:\/\/magecurious.com\/blog\/wp-content\/uploads\/2023\/11\/image_2023_11_24T12_37_42_448Z.png","jetpack_sharing_enabled":true,"_links":{"self":[{"href":"https:\/\/magecurious.com\/blog\/wp-json\/wp\/v2\/posts\/871","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/magecurious.com\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/magecurious.com\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/magecurious.com\/blog\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/magecurious.com\/blog\/wp-json\/wp\/v2\/comments?post=871"}],"version-history":[{"count":0,"href":"https:\/\/magecurious.com\/blog\/wp-json\/wp\/v2\/posts\/871\/revisions"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/magecurious.com\/blog\/wp-json\/wp\/v2\/media\/872"}],"wp:attachment":[{"href":"https:\/\/magecurious.com\/blog\/wp-json\/wp\/v2\/media?parent=871"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/magecurious.com\/blog\/wp-json\/wp\/v2\/categories?post=871"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/magecurious.com\/blog\/wp-json\/wp\/v2\/tags?post=871"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}