{"id":1406,"date":"2024-04-26T17:49:52","date_gmt":"2024-04-26T12:19:52","guid":{"rendered":"https:\/\/magecurious.com\/blog\/?p=1406"},"modified":"2025-01-28T13:41:20","modified_gmt":"2025-01-28T08:11:20","slug":"how-to-create-custom-widget-in-magento-2","status":"publish","type":"post","link":"https:\/\/magecurious.com\/blog\/how-to-create-custom-widget-in-magento-2\/","title":{"rendered":"How To Create A Custom Widget In Magento 2"},"content":{"rendered":"\n<p>Hello Everyone,&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;<\/p>\n\n\n\n<p>In this blog, we will learn how to create a custom widget in Magento 2.<\/p>\n\n\n\n<p>Widget is a feature of Magento to display dynamic content to page and block.<\/p>\n\n\n\n<p>By default, Magento 2 provides widgets like CMS Page Link, CMS Static Block, Orders, and returns, etc.<\/p>\n\n\n\n<p>But sometimes we also need to create our custom widget.<\/p>\n\n\n\n<p>Without wasting your time, let us guide you straight away. Follow the easy steps given below to Create a Custom Widget in <a href=\"https:\/\/magecurious.com\/magento-2-extensions.html\" title=\"Magento 2\">Magento 2<\/a>.&nbsp;<\/p>\n\n\n\n<h2 class=\"wp-block-heading\">STEPS FOR CREATE CUSTOM WIDGET IN MAGENTO 2<\/h2>\n\n\n\n<p><strong>Step 1: Create widget.xml file<\/strong><\/p>\n\n\n\n<p><strong>app\/code\/Vendor\/Extension\/etc\/widget.xml<\/strong><\/p>\n\n\n<div class=\"wp-block-syntaxhighlighter-code \"><pre class=\"brush: php; title: ; notranslate\" title=\"\">\n&lt;?xml version=&quot;1.0&quot; encoding=&quot;UTF-8&quot;?&gt;\n\n&lt;widgets xmlns:xsi=&quot;http:\/\/www.w3.org\/2001\/XMLSchema-instance&quot;\n\n\u00a0\u00a0\u00a0\u00a0xsi:noNamespaceSchemaLocation=&quot;urn:magento:module:Magento_Widget:etc\/widget.xsd&quot;&gt;\n\n\u00a0\u00a0\u00a0\u00a0&lt;widget id=&quot;magecurious_custom_widget&quot; class=&quot;Vendor\\Extension\\Block\\Widget\\Widget&quot;&gt;\n\n\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0&lt;label&gt;Magecurious Custom Widget&lt;\/label&gt;\n\n\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0&lt;description&gt;&lt;\/description&gt;\n\n\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0&lt;parameters&gt;\n\n\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0&lt;parameter name=&quot;title&quot; xsi:type=&quot;text&quot; visible=&quot;true&quot; required=&quot;true&quot;&gt;\n\n\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0&lt;label translate=&quot;true&quot;&gt;Title&lt;\/label&gt;\n\n\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0&lt;\/parameter&gt;\n\n\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0&lt;parameter name=&quot;description&quot; xsi:type=&quot;block&quot; visible=&quot;true&quot; required=&quot;true&quot;&gt;\n\n\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0&lt;label translate=&quot;true&quot;&gt;Description&lt;\/label&gt;\n\n\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0&lt;block class=&quot;Vendor\\Extension\\Block\\Adminhtml\\Widget\\TextArea&quot;\/&gt;\n\n\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0&lt;\/parameter&gt;\n\n\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0&lt;\/parameters&gt;\n\n\u00a0\u00a0\u00a0&lt;\/widget&gt;\n\n&lt;\/widgets&gt;\n<\/pre><\/div>\n\n\n<p><strong>Step 2: Create a Widget.php file<\/strong><\/p>\n\n\n\n<p><strong>app\/code\/Vendor\/Extension\/Block\/Widget\/Widget.php<\/strong><\/p>\n\n\n<div class=\"wp-block-syntaxhighlighter-code \"><pre class=\"brush: php; title: ; notranslate\" title=\"\">\n&lt;?php\n\nnamespace Vendor\\Extension\\Block\\Widget;\n\nuse Magento\\Framework\\View\\Element\\Template;\n\nuse Magento\\Widget\\Block\\BlockInterface;\n\nclass Widget extends Template implements BlockInterface\n\n{\n\n\u00a0\u00a0\u00a0protected $_template = &quot;Magecurious_HelloWorld::widget\/widget.phtml&quot;;\n\n}\n<\/pre><\/div>\n\n\n<p><strong>Step 3: Create TextArea.php file<\/strong><\/p>\n\n\n\n<p><strong>app\/code\/Vendor\/Extension\/Block\/Adminhtml\/Widget\/TextArea.php<\/strong><\/p>\n\n\n<div class=\"wp-block-syntaxhighlighter-code \"><pre class=\"brush: php; title: ; notranslate\" title=\"\">\n&lt;?php\n\nnamespace Vendor\\Extension\\Block\\Adminhtml\\Widget;\n\nuse Magento\\Framework\\Data\\Form\\Element\\AbstractElement;\n\nclass TextArea extends \\Magento\\Backend\\Block\\Template\n\n{\n\n\u00a0\u00a0\u00a0\u00a0\/**\n\n\u00a0\u00a0\u00a0\u00a0\u00a0* @var \\Magento\\Framework\\Data\\Form\\Element\\Factory\n\n\u00a0\u00a0\u00a0\u00a0\u00a0*\/\n\n\u00a0\u00a0\u00a0\u00a0protected $elementFactory;\n\n\u00a0\u00a0\u00a0\u00a0\/**\n\n\u00a0\u00a0\u00a0\u00a0\u00a0* @param \\Magento\\Backend\\Block\\Template\\Context $context\n\n\u00a0\u00a0\u00a0\u00a0\u00a0* @param \\Magento\\Framework\\Data\\Form\\Element\\Factory $elementFactory\n\n\u00a0\u00a0\u00a0\u00a0\u00a0* @param array $data\n\n\u00a0\u00a0\u00a0\u00a0\u00a0*\/\n\n\u00a0\u00a0\u00a0\u00a0public function __construct(\n\n\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\\Magento\\Backend\\Block\\Template\\Context $context,\n\n\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\\Magento\\Framework\\Data\\Form\\Element\\Factory $elementFactory,\n\n\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0array $data = &#x5B;]\n\n\u00a0\u00a0\u00a0\u00a0) {\n\n\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0$this-&gt;elementFactory = $elementFactory;\n\n\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0parent::__construct($context, $data);\n\n\u00a0\u00a0\u00a0\u00a0}\n\n\u00a0\u00a0\u00a0\u00a0\/**\n\n\u00a0\u00a0\u00a0\u00a0\u00a0* Prepare chooser element HTML\n\n\u00a0\u00a0\u00a0\u00a0\u00a0*\n\n\u00a0\u00a0\u00a0\u00a0\u00a0* @param \\Magento\\Framework\\Data\\Form\\Element\\AbstractElement $element Form Element\n\n\u00a0\u00a0\u00a0\u00a0\u00a0* @return \\Magento\\Framework\\Data\\Form\\Element\\AbstractElement\n\n\u00a0\u00a0\u00a0\u00a0\u00a0*\/\n\n\u00a0\u00a0\u00a0\u00a0public function prepareElementHtml(AbstractElement $element)\n\n\u00a0\u00a0\u00a0\u00a0{\n\n\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0$input = $this-&gt;elementFactory-&gt;create(&quot;textarea&quot;, &#x5B;&#039;data&#039; =&gt; $element-&gt;getData()]);\n\n\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0$input-&gt;setId($element-&gt;getId());\n\n\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0$input-&gt;setForm($element-&gt;getForm());\n\n\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0$input-&gt;setClass(&quot;widget-option input-textarea admin__control-text&quot;);\n\n\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0if ($element-&gt;getRequired()) {\n\n\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0$input-&gt;addClass(&#039;required-entry&#039;);\n\n\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0}\n\n\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0$element-&gt;setData(&#039;after_element_html&#039;, $input-&gt;getElementHtml());\n\n\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0return $element;\n\n\u00a0\u00a0\u00a0\u00a0}\n\n}\n<\/pre><\/div>\n\n\n<p><strong>Step 4: Create widget.phtml file<\/strong><\/p>\n\n\n\n<p><strong>app\/code\/Vendor\/Extension\/view\/frontend\/templates\/widget\/widget.phtml<\/strong><\/p>\n\n\n<div class=\"wp-block-syntaxhighlighter-code \"><pre class=\"brush: php; title: ; notranslate\" title=\"\">\n&lt;div class=&quot;maincontent&quot;&gt;\n\n\u00a0\u00a0\u00a0\u00a0&lt;div class=&quot;title&quot;&gt;\n\n\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0&lt;span class=&quot;widget-title&quot;&gt;&lt;?php echo __(&quot;Title : &quot;); ?&gt;&lt;\/span&gt;\n\n\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0&lt;span class=&quot;widget-title-val&quot;&gt;&lt;?php echo $block-&gt;getData(&#039;title&#039;); ?&gt;&lt;\/span&gt;\n\n\u00a0\u00a0\u00a0\u00a0&lt;\/div&gt;\n\n\u00a0\u00a0\u00a0\u00a0&lt;div class=&quot;description&quot;&gt;\n\n\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0&lt;span class=&quot;widget-desc&quot;&gt;&lt;?php echo __(&quot;Description : &quot;); ?&gt;&lt;\/span&gt;\n\n\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0&lt;span class=&quot;widget-desc-val&quot;&gt;&lt;?php echo $block-&gt;getData(&#039;description&#039;); ?&gt;&lt;\/span&gt;\n\n\u00a0\u00a0\u00a0\u00a0&lt;\/div&gt;\n\n&lt;\/div&gt;\n<\/pre><\/div>\n\n\n<p><strong>Step 5: Finally run the below commands<\/strong><\/p>\n\n\n<div class=\"wp-block-syntaxhighlighter-code \"><pre class=\"brush: php; title: ; notranslate\" title=\"\">\n$ php bin\/magento cache: clean\n\n$ php bin\/magento cache: flush\n<\/pre><\/div>\n\n\n<p><strong>Step 6: Output:<\/strong><\/p>\n\n\n\n<p>Go to content -&gt; Elements -&gt; Widgets -&gt; Add Widgets<\/p>\n\n\n\n<figure class=\"wp-block-image\"><img decoding=\"async\" src=\"https:\/\/lh7-us.googleusercontent.com\/xvvxOCIdEVDLhCddFPPDivf3I2iy-wNAoNrTPYM98FHb-nwSaq4mCqit4equKb2Kr7pGY-sm3TjeY02buW9M6ddF6JznawmuJZnUvM1YCA7jJiiP8LGmd7dRJrO_1_YNpUay8OteRL3qu44mXuP54T0\" alt=\"\"\/><\/figure>\n\n\n\n<div style=\"height:20px\" aria-hidden=\"true\" class=\"wp-block-spacer\"><\/div>\n\n\n\n<p>Use the Layout update option to display the widget on the home page:<\/p>\n\n\n\n<figure class=\"wp-block-image\"><img decoding=\"async\" src=\"https:\/\/lh7-us.googleusercontent.com\/Sxvk6oQC73NPMuKSb2f-yQkhgUl2xuj3PeefS2VWlcVkVVtMV6T6z_PYF0WZmoMsAguJi8uK312fJxAeYyW2wmhtPt0F9aLfm-nRuT4iJuQYryh_ybpewK5ENZJiTF-GtvW5G2sv0zhF1HfLwAd7TFg\" alt=\"\"\/><\/figure>\n\n\n\n<div style=\"height:20px\" aria-hidden=\"true\" class=\"wp-block-spacer\"><\/div>\n\n\n\n<p>In the front area:<\/p>\n\n\n\n<figure class=\"wp-block-image\"><img decoding=\"async\" src=\"https:\/\/lh7-us.googleusercontent.com\/fXhLCv3UMjAJHI15LfC2Qa5a0aVGp4O3ZCKhfhvCyGvULZGWwr2msMPLdsSWqEzSJKyk8fmcKc2992jiDiFPVYVbLNe7Z8aOemqO5BPCe1FhJVG4YJpQY1JpQ6TJikQ7HzPguz7UUfSU8G3YMYcltRg\" alt=\"\"\/><\/figure>\n\n\n\n<div style=\"height:20px\" aria-hidden=\"true\" class=\"wp-block-spacer\"><\/div>\n\n\n\n<p>Final Thoughts:<\/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 a Custom Widget 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 on 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--1406 \"  data-post-id=\"1406\">    <!-- 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 rmp-icon--full-highlight\"><\/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 rmp-icon--full-highlight\"><\/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 rmp-icon--full-highlight\"><\/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 rmp-icon--full-highlight\"><\/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 rmp-icon--full-highlight\"><\/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 \">      Average rating <span class=\"rmp-rating-widget__results__rating js-rmp-avg-rating\">5<\/span> \/ 5. Vote count: <span class=\"rmp-rating-widget__results__votes js-rmp-vote-count\">1<\/span>    <\/p>    <p class=\"rmp-rating-widget__not-rated js-rmp-not-rated rmp-rating-widget__not-rated--hidden\">      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,&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; In this blog, we will learn how to create a custom widget in Magento 2. Widget is a feature of Magento to display dynamic content to page and block. By default, Magento 2 provides widgets like CMS Page Link, CMS Static Block, Orders, and returns, etc. But sometimes we also need to create [&hellip;]<\/p>\n","protected":false},"author":1,"featured_media":1411,"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-1406","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 A Custom Widget In Magento 2 - Magecurious<\/title>\n<meta name=\"description\" content=\"Discover how to create a custom widget in Magento 2 to add unique content and functionality to your store&#039;s pages.\" \/>\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-custom-widget-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 A Custom Widget In Magento 2 - Magecurious\" \/>\n<meta property=\"og:description\" content=\"Discover how to create a custom widget in Magento 2 to add unique content and functionality to your store&#039;s pages.\" \/>\n<meta property=\"og:url\" content=\"https:\/\/magecurious.com\/blog\/how-to-create-custom-widget-in-magento-2\/\" \/>\n<meta property=\"og:site_name\" content=\"Magecurious\" \/>\n<meta property=\"article:published_time\" content=\"2024-04-26T12:19:52+00:00\" \/>\n<meta property=\"article:modified_time\" content=\"2025-01-28T08:11:20+00:00\" \/>\n<meta property=\"og:image\" content=\"https:\/\/magecurious.com\/blog\/wp-content\/uploads\/2024\/04\/CUSTOM-WIDDGETS-1.png\" \/>\n\t<meta property=\"og:image:width\" content=\"1200\" \/>\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 A Custom Widget In Magento 2 - Magecurious","description":"Discover how to create a custom widget in Magento 2 to add unique content and functionality to your store's pages.","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-custom-widget-in-magento-2\/","og_locale":"en_US","og_type":"article","og_title":"How To Create A Custom Widget In Magento 2 - Magecurious","og_description":"Discover how to create a custom widget in Magento 2 to add unique content and functionality to your store's pages.","og_url":"https:\/\/magecurious.com\/blog\/how-to-create-custom-widget-in-magento-2\/","og_site_name":"Magecurious","article_published_time":"2024-04-26T12:19:52+00:00","article_modified_time":"2025-01-28T08:11:20+00:00","og_image":[{"width":1200,"height":496,"url":"https:\/\/magecurious.com\/blog\/wp-content\/uploads\/2024\/04\/CUSTOM-WIDDGETS-1.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-custom-widget-in-magento-2\/#article","isPartOf":{"@id":"https:\/\/magecurious.com\/blog\/how-to-create-custom-widget-in-magento-2\/"},"author":{"name":"Magecurious","@id":"https:\/\/magecurious.com\/blog\/#\/schema\/person\/6bced7da0991e7fbbd4550006a6494e2"},"headline":"How To Create A Custom Widget In Magento 2","datePublished":"2024-04-26T12:19:52+00:00","dateModified":"2025-01-28T08:11:20+00:00","mainEntityOfPage":{"@id":"https:\/\/magecurious.com\/blog\/how-to-create-custom-widget-in-magento-2\/"},"wordCount":267,"commentCount":0,"publisher":{"@id":"https:\/\/magecurious.com\/blog\/#organization"},"image":{"@id":"https:\/\/magecurious.com\/blog\/how-to-create-custom-widget-in-magento-2\/#primaryimage"},"thumbnailUrl":"https:\/\/magecurious.com\/blog\/wp-content\/uploads\/2024\/04\/CUSTOM-WIDDGETS-1.png","articleSection":["Magento 2 Blog"],"inLanguage":"en-US","potentialAction":[{"@type":"CommentAction","name":"Comment","target":["https:\/\/magecurious.com\/blog\/how-to-create-custom-widget-in-magento-2\/#respond"]}]},{"@type":"WebPage","@id":"https:\/\/magecurious.com\/blog\/how-to-create-custom-widget-in-magento-2\/","url":"https:\/\/magecurious.com\/blog\/how-to-create-custom-widget-in-magento-2\/","name":"How To Create A Custom Widget In Magento 2 - Magecurious","isPartOf":{"@id":"https:\/\/magecurious.com\/blog\/#website"},"primaryImageOfPage":{"@id":"https:\/\/magecurious.com\/blog\/how-to-create-custom-widget-in-magento-2\/#primaryimage"},"image":{"@id":"https:\/\/magecurious.com\/blog\/how-to-create-custom-widget-in-magento-2\/#primaryimage"},"thumbnailUrl":"https:\/\/magecurious.com\/blog\/wp-content\/uploads\/2024\/04\/CUSTOM-WIDDGETS-1.png","datePublished":"2024-04-26T12:19:52+00:00","dateModified":"2025-01-28T08:11:20+00:00","description":"Discover how to create a custom widget in Magento 2 to add unique content and functionality to your store's pages.","breadcrumb":{"@id":"https:\/\/magecurious.com\/blog\/how-to-create-custom-widget-in-magento-2\/#breadcrumb"},"inLanguage":"en-US","potentialAction":[{"@type":"ReadAction","target":["https:\/\/magecurious.com\/blog\/how-to-create-custom-widget-in-magento-2\/"]}]},{"@type":"ImageObject","inLanguage":"en-US","@id":"https:\/\/magecurious.com\/blog\/how-to-create-custom-widget-in-magento-2\/#primaryimage","url":"https:\/\/magecurious.com\/blog\/wp-content\/uploads\/2024\/04\/CUSTOM-WIDDGETS-1.png","contentUrl":"https:\/\/magecurious.com\/blog\/wp-content\/uploads\/2024\/04\/CUSTOM-WIDDGETS-1.png","width":1200,"height":496},{"@type":"BreadcrumbList","@id":"https:\/\/magecurious.com\/blog\/how-to-create-custom-widget-in-magento-2\/#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"Home","item":"https:\/\/magecurious.com\/blog\/"},{"@type":"ListItem","position":2,"name":"How To Create A Custom Widget 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\/2024\/04\/CUSTOM-WIDDGETS-1.png","jetpack_sharing_enabled":true,"_links":{"self":[{"href":"https:\/\/magecurious.com\/blog\/wp-json\/wp\/v2\/posts\/1406","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=1406"}],"version-history":[{"count":0,"href":"https:\/\/magecurious.com\/blog\/wp-json\/wp\/v2\/posts\/1406\/revisions"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/magecurious.com\/blog\/wp-json\/wp\/v2\/media\/1411"}],"wp:attachment":[{"href":"https:\/\/magecurious.com\/blog\/wp-json\/wp\/v2\/media?parent=1406"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/magecurious.com\/blog\/wp-json\/wp\/v2\/categories?post=1406"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/magecurious.com\/blog\/wp-json\/wp\/v2\/tags?post=1406"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}