bitpolar/categoryimgwidget 1.1.0

Bitpolar Category List with custom Thumbnail Widget

Type

magento2-module

License

OSL-3.0

Requires
Requires (dev)

None

Suggests

None

Provides

None

Conflicts

None

Replaces

None

Magento 2 Widget: Category List with optional thumbnail or category image

Based on
https://github.com/studioraz/magento2-category-image
https://github.com/MageMontreal/magento2-category-list-widget

Features

  • Add category list as a widget
  • Manage Image Size Output
  • Assign Custom Parent Category
  • Or list any category
  • Add and use additional thumbnail as preview image
  • Images are resized and cached to the user defined sizes
  • Uses the placeholder image as default

Composer Installation Instructions

  composer require bitpolar/categoryimgwidget

Enable Bitpolar/CategoryImgWidget Module

to Enable this module you need to follow these steps:

  • Enable the Module
    bin/magento module:enable Bitpolar_CategoryImgWidget
  • Run Upgrade Setup
    bin/magento setup:upgrade
  • Re-Compile (in-case you have compilation enabled)
    bin/magento setup:di:compile

How to add new category image ?

The module already creates one image field called Thumbnail.

If you need to additional image fields follow these steps:

  1. Create an upgrade data script to create the new category image attribute.
  2. Create new upload class for the new image attribute by copy-pasting the file Controller/Adminhtml/Category/Thumbnail/Upload.php. Change the class name and the following line:
  $result = $this->imageUploader->saveFileToTmpDir('{image-attribute-code}');
  1. Add the new fields to the admin html category form at view/adminhtml/ui_component/category_form.xml and change: the field name, the label and the uploader Url
 <field name="{image-attribute-code}">
            <argument name="data" xsi:type="array">
                <item name="config" xsi:type="array">
                    <item name="dataType" xsi:type="string">string</item>
                    <item name="source" xsi:type="string">category</item>
                    <item name="label" xsi:type="string" translate="true">{Image Label}</item>
                    <item name="visible" xsi:type="boolean">true</item>
                    <item name="formElement" xsi:type="string">fileUploader</item>
                    <item name="elementTmpl" xsi:type="string">ui/form/element/uploader/uploader</item>
                    <item name="previewTmpl" xsi:type="string">Magento_Catalog/image-preview</item>
                    <item name="required" xsi:type="boolean">false</item>
                    <item name="sortOrder" xsi:type="number">41</item>
                    <item name="uploaderConfig" xsi:type="array">
                        <item name="url" xsi:type="url" path="categoryimage/category_thumbnail/{upload-class-file-name}"/>
                    </item>
                </item>
            </argument>
        </field>
  1. Add the new image attribute code to the helper class Helper/Category.php line 16
public function getAdditionalImageTypes()
    {
        return array('thumbnail', '{image-attribute-code}');
    }
  1. Repeat step 4 in the Controller class Controller/Adminhtml/Category/Save.php line 18
protected function getAdditionalImages() {
        return array('thumbnail', '{image-attribute-code}');
}

If everything went well you should be able to see the new field on the category screen under the Content group. You should also be able to upload, save and delete the image file successfully.

How to show the new image on frontend ?

The module comes with a block that can print any new image field on the category page frontend. Just add the following XML block under the container/block you would like the image to appear.

 <block class="Bitpolar\CategoryImgWidget\Block\Image" name="bitpolar.category.image" template="Bitpolar_CategoryImgWidget::image.phtml">
    <arguments>
        <argument name="image_code" xsi:type="string">{image-attribute-code}</argument>
        <argument name="css_class" xsi:type="string">{div-css-class}</argument>
    </arguments>
</block>

The above block can print category images ONLY on category pages cause it assumes there is already stored category model in core registry. If you need to print the image on other pages use the following code snippet.

$category = 'load a category model class here'; // the decision how to load category model object is up to you.
$helper    = $this->helper('Bitpolar\CategoryImgWidget\Helper\Category');
$imageUrl = $helper->getImageUrl($category->getData('image-attribute-code'));