Home >Learn How to Configure Theme Properties in Magento 2

Learn How to Configure Theme Properties in Magento 2

Images are one of decisive factors to impress online customers and encourage them to purchase products. In Magento, image properties are stored in the view.xml file. 

Today, let’s find out more information about this file together. 

 As mentioned above, product images are saved in the view.xml file by default. This file is placed in the <theme_dir>/etc/view.xml folder. 

For example: The view.xml file of Blank Theme belongs to this folder: vendor/magento/theme-frontend-blank/etc/view.xml.

1. Config image properties in the view.xml file

In this file, image properties are configured within the scope <images module=”Magento_Catalog”> element:

<media>
    <images module="Magento_Catalog">

    ...

    </images>

</media>

Image properties which are configured for each image are defined by id and type properties of image element: 

<images module="Magento_Catalog">

   <image id="unique_image_id" type="image_type">

   ...

   </image>

</images>

Detailed image properties

  • id is the only parameter and used in the .phtml template file to identify the image attributes at a specific position on a page: images of related products on product details page, product images on the product list / grid on categories. 

For example, the Image ID used in the .phtml file is as follows: 

Detailed-image- properties-magento-2

  • The type defines which images are displayed, or which images are assigned in admin-> catalog-> product-> Images Videos section. Each image has a different role, and it allows loading various images such as small images and large images with the following values:

+ image – corresponds to the Base Image role

+ small_image – corresponds to the Small Image role 

+ swatch_image – corresponds to the Swatch Image role 

+ swatch_thumb – corresponds to the Swatch Image role

+ thumbnail – corresponds to the Thumbnail Image role 

type-of-images

  • In case you want to change or overwrite the value of view.xml file, you need to copy the entire view.xml file into your theme and change the value.
  • To resize the product image in magento 2, open the file <theme_dir> /etc/view.xml, find the image with the correct ID and update the width and height parameters.

For example, resizing an image ID = product_small_image allows updating the product image size to 180×135.

<images module="Magento_Catalog">

    <image id="product_small_image" type="small_image">

        <width>180</width> <!-- Image width in px -->

        <height>135</height> <!-- Image height in px -->

    </image>

</images>

Full list of image parameters

Magento can resize images, keep aspect ratio, keep image aspect ratio transparent, and crop product images.

  • width: specifies image width in pixels and is used to resize the product image.

+ Type: Integer

+ Default value: None.

  • height: specifies image height in pixels, and is used to resize the product image.

+  Type: Integer             

 + Default value: None

  • constrain: If set to true, the image is smaller than the configuration requirements, and cannot be enlarged.

+  Type: Boolean

+ Default value: true

  • aspect_ratio: If set to true, the ratio of image width and height are not changed without image fragmentation.

+  Type: Boolean.                 

 + Default value: true.

aspect-ratio-image

  • frame: If set to true, the image is not cropped. The attribute is only applied in case the aspect_ratio is set to true. 

+  Type: Boolean.                             

+ Default value: true.

frame-image

  • transparency: If set to true, the image with transparent background is saved. If set to false, the image will have a white background (by default).

+  Type: Boolean.                              

+ Default value: true.

  • background: This is the background color for the image, and does not apply to transparent images if transparency is set to true. It is used to remove the white image frame when you resize the image and adjust the background color to match with your theme.

+ Type: string.

+ Default Value: [255, 255, 255].

background-image

2. Resize catalog images

When you modify the view.xml file and want to update the image size that you have changed, you will use the ssh command: 

php <magento install dir>/bin/magento catalog:images:resize

3. Config variables in view.xml file

The properties of the var variable are configured for individual modules, defined by the name of the module: 

<vars module="Magento_Catalog">

    <var name="breakpoints">

        <var name="mobile">

            <var name="conditions">

                <var name="max-width">767px</var>

            </var>

            ...

        </var>

    </var>

    ...

</vars>

Any block that has been extended AbstractBlock can get variable values with the getVar method: 

$block->getVar($name, $module = null)

Variables are not only used in view.xml but also in various sections such as Email templates, Blocks and content pages. We will continue to learn about predefined variables and customized variables in Magento 2.

Predefined Variables

Here is the list of variables in default Magento:  In the view.xml file, default variables of the theme are set as follows:

<vars module="Magento_Catalog">

   <!-- Gallery and magnifier theme settings. Start -->

   <var name="gallery">

       <var name="nav">thumbs</var> <!-- Gallery navigation style (false/thumbs/dots) -->

       <var name="loop">true</var> <!-- Gallery navigation loop (true/false) -->

       <var name="keyboard">true</var> <!-- Turn on/off keyboard arrows navigation (true/false) -->

       <var name="arrows">true</var> <!-- Turn on/off arrows on the sides preview (true/false) -->

       <var name="caption">false</var> <!-- Display alt text as image title (true/false) -->

       <var name="allowfullscreen">true</var> <!-- Turn on/off fullscreen (true/false) -->

       <var name="navdir">horizontal</var> <!-- Sliding direction of thumbnails (horizontal/vertical) -->

       <var name="navarrows">true</var> <!-- Turn on/off on the thumbs navigation sides arrows(true/false) -->

       <var name="navtype">slides</var> <!-- Sliding type of thumbnails (slides/thumbs) -->

       <var name="transition">

           <var name="effect">slide</var> <!-- Sets transition effect for slides changing (slide/crossfade/dissolve) -->

           <var name="duration">500</var> <!-- Sets transition duration in ms -->

       </var>

       <var name="fullscreen">

           <var name="nav">thumbs</var> <!-- Fullscreen navigation style (false/thumbs/dots) -->

           <var name="loop">true</var> <!-- Fullscreen navigation loop (true/false/null) -->

           <var name="arrows">false</var> <!-- Turn on/off arrows on the sides preview in fullscreen (true/false/null) -->

           <var name="caption">false</var> <!-- Display alt text as image title in fullscreen(true/false) -->

           <var name="navdir">horizontal</var> <!--Sliding direction of thumbnails in fullscreen(horizontal/vertical)  -->

           <var name="navtype">slides</var> <!-- Sliding type of thumbnails (slides/thumbs) -->

           <var name="transition">

               <var name="effect">dissolve</var> <!-- Sets transition effect for slides changing (slide/crossfade/dissolve) -->

               <var name="duration">500</var> <!-- Sets transition duration in ms -->

           </var>

       </var>

   </var>

   <var name="magnifier">

       <var name="fullscreenzoom">20</var>  <!-- Zoom for fullscreen (integer)-->

       <var name="top"></var> <!-- Top position of magnifier -->

       <var name="left"></var> <!-- Left position of magnifier -->

       <var name="width"></var> <!-- Width of magnifier block -->

       <var name="height"></var> <!-- Height of magnifier block -->

       <var name="eventType">hover</var> <!-- Action that atcivates zoom (hover/click) -->

       <var name="enabled">false</var> <!-- Turn on/off magnifier (true/false) -->

   </var>

   <var name="breakpoints">

       <var name="mobile">

           <var name="conditions">

               <var name="max-width">767px</var>

           </var>

           <var name="options">

               <var name="options">

                   <var name="nav">dots</var>

               </var>

           </var>

       </var>

   </var>

   <!-- end. Gallery and magnifier theme settings -->

   <var name="product_small_image_sidebar_size">100</var>  <!-- Override for small product image -->

   <var name="product_base_image_size">275</var>           <!-- Override for base product image -->

   <var name="product_base_image_icon_size">48</var>       <!-- Base product image icon size -->

   <var name="product_list_image_size">166</var>           <!-- New Product image size used in product list -->

   <var name="product_zoom_image_size">370</var>           <!-- New Product image size used for zooming -->

   <var name="product_image_white_borders">0</var>

</vars>

<vars module="Magento_Bundle">

   <var name="product_summary_image_size">58</var>         <!-- New Product image size used for summary block-->

</vars>

<vars module="Js_Bundle">

   <var name="bundle_size">1MB</var>

</vars>

We also have email template variables:

  • Email Footer Template: {{template config_path=”design/email/footer_template”}}
  • Email Header Template: {{template config_path=”design/email/header_template”}}
  • Email Logo Image Alt: {{var logo_alt}}
  • Email Logo Image URL: {{var logo_url}}
  • Email Logo Image Height: {{var logo_height}}
  • Email Logo Image Width: {{var logo_width}}
  • Template CSS: {{var template_styles|raw}}

Store Contact Information variables

  • Base Unsecure URL: {{config path=”web/unsecure/base_url”}}
  • Base Secure URL: {{config path=”web/secure/base_url”}}
  • General Contact Name: {{config path=”trans_email/ident_general/name”}}
  • General Contact Email: {{config path=”trans_email/ident_general/email”}}
  • Sales Representative Contact Name: {{config path=”trans_email/ident_sales/name”}}
  • Sales Representative Contact Email: {{config path=”trans_email/ident_sales/email”}}
  • Custom1 Contact Name: {{config path=”trans_email/ident_custom1/name”}}
  • Custom1 Contact Email: {{config path=”trans_email/ident_custom1/email”}}
  • Custom2 Contact Name: {{config path=”trans_email/ident_custom2/name”}}
  • Custom2 Contact Email: {{config path=”trans_email/ident_custom2/email”}}
  • Store Name: {{config path=”general/store_information/name”}}
  • Store Phone Telephone: {{config path=”general/store_information/phone”}}
  • Store Hours: {{config path=”general/store_information/hours”}}
  • Country: {{config path=”general/store_information/country_id”}}
  • Region/State: {{config path=”general/store_information/region_id”}}
  • Zip/Postal Code: {{config path=”general/store_information/postcode”}}
  • City: {{config path=”general/store_information/city”}}
  • Street Address 1: {{config path=”general/store_information/street_line1”}}
  • Street Address 2: {{config path=”general/store_information/street_line2”}}
  • Store Contact Address: {{config path=”general/store_information/address”}}

New Account Template variables: 

  • Customer Account URL: {{var this.getUrl($store, ‘customer/account/’)}}
  • Customer Email: {{var customer.email}}
  • Customer Name: {{var customer.name}}

New Order Template variables:

  • Billing Address: {{var formattedBillingAddress|raw}}
  • Email Order Note: {{var order.getEmailCustomerNote()}}
  • Order ID: {{var order.increment_id}}
  • Order Items Grid: {{layout handle=”sales_email_order_items” order=$order area=”frontend”}}
  • Payment Details: {{var payment_html|raw}}
  • Shipping Address: {{var formattedShippingAddress|raw}}
  • Shipping Description: {{var order.getShippingDescription()}

    Custom Variables

    To customize variables when creating a custom theme, you can create a view.xml file to override the variables you want to change.

    app\design\frontend\Themes\Yourtheme\etc\view.xml

    For example: In the default theme, breakpoint on mobile screens has the max-with as 767. If you want to change on the mobile max-with screen to 600 in the newly created theme, you will change as follows:

    <var name="breakpoints">
            <var name="mobile">
    
                <var name="conditions">
    
                    <var name="max-width">600px</var>
    
                </var>
    
            </var>
    
        </var>

    To create Custom Variable in admin, follow these steps:

    Step 1: Navigate to Admin ⇒ System ⇒ Custom Variables.

    Step 2: Click the Add New Variable button.

    Step 3: In the Variable Code field, enter lowercase letters without spaces, for example: dev_name.

new-custom-variableEnter Variable Name, Variable HTML Value, Variable Plain Value and click Save.Now we have a custom variable with the developer name. We will use this variable in the promotion page.

promotion-page

result

<exclude> property

The exclude tag is used to list browser resources that need to be excluded from the applied html page.

It is often used to remove files from the JavaScript bundling process. (JavaScript bundling is an optimization technique that you can use to reduce the number of server requests for JavaScript files. Bundling does this by merging multiple JavaScript files together into one file to reduce the number of page requests.)

Example: The following code will remove the files from the bundling process.

<exclude>
    <item type="file">Lib::jquery/jquery.min.js</item>

    <item type="file">Lib::jquery/jquery-ui-1.9.2.js</item>

    <item type="file">Lib::jquery/jquery.ba-hashchange.min.js</item>

    <item type="file">Lib::jquery/jquery.details.js</item>

    <item type="file">Lib::jquery/jquery.details.min.js</item>

    <item type="file">Lib::jquery/jquery.hoverIntent.js</item>

    <item type="file">Lib::jquery/colorpicker/js/colorpicker.js</item>

    <item type="file">Lib::requirejs/require.js</item>

    <item type="file">Lib::requirejs/text.js</item>

    <item type="file">Lib::date-format-normalizer.js</item>

    <item type="file">Lib::legacy-build.min.js</item>

    <item type="file">Lib::mage/captcha.js</item>

    <item type="file">Lib::mage/dropdown_old.js</item>

    <item type="file">Lib::mage/list.js</item>

    <item type="file">Lib::mage/loader_old.js</item>

    <item type="file">Lib::mage/webapi.js</item>

    <item type="file">Lib::mage/zoom.js</item>

    <item type="file">Lib::mage/translate-inline-vde.js</item>

    <item type="file">Lib::mage/requirejs/mixins.js</item>

    <item type="file">Lib::mage/requirejs/static.js</item>

    <item type="file">Magento_Customer::js/zxcvbn.js</item>

    <item type="file">Magento_Catalog::js/zoom.js</item>

    <item type="file">Magento_Ui::js/lib/step-wizard.js</item>

    <item type="file">Magento_Ui::js/form/element/ui-select.js</item>

    <item type="file">Magento_Ui::js/form/element/file-uploader.js</item>

    <item type="file">Magento_Ui::js/form/components/insert.js</item>

    <item type="file">Magento_Ui::js/form/components/insert-listing.js</item>

    <item type="directory">Magento_Ui::js/timeline</item>

    <item type="directory">Magento_Ui::js/grid</item>

    <item type="directory">Magento_Ui::js/dynamic-rows</item>

    <item type="directory">Magento_Ui::templates/timeline</item>

    <item type="directory">Magento_Ui::templates/grid</item>

    <item type="directory">Magento_Ui::templates/dynamic-rows</item>

    <item type="directory">Magento_Swagger::swagger-ui</item>

    <item type="directory">Lib::modernizr</item>

    <item type="directory">Lib::tiny_mce</item>

    <item type="directory">Lib::varien</item>

    <item type="directory">Lib::jquery/editableMultiselect</item>

    <item type="directory">Lib::jquery/jstree</item>

    <item type="directory">Lib::jquery/fileUploader</item>

    <item type="directory">Lib::css</item>

    <item type="directory">Lib::lib</item>

    <item type="directory">Lib::extjs</item>

    <item type="directory">Lib::prototype</item>

    <item type="directory">Lib::scriptaculous</item>

    <item type="directory">Lib::less</item>

    <item type="directory">Lib::mage/adminhtml</item>

    <item type="directory">Lib::mage/backend</item>

</exclude>

 

3. Conclusion

We hope this article brings you a lot of useful knowledge about Magento 2 Configure Theme Properties. Please keep updated with us for the next article: Layout Overview.

< Previous Post
Next Post >
+ posts