Skip to Content

Custom Scripts

General approach

You can add any custom js file to the Breeze theme using component registration approach. Create breeze_default.xml layout update file with the following code inside:

<referenceBlock name="breeze.js">
    <arguments>
        <argument name="bundles" xsi:type="array">
            <item name="default" xsi:type="array">
                <item name="items" xsi:type="array">
                    <item name="js-from-theme-folder" xsi:type="string">
                        js/breeze/my-custom-file
                    </item>
                    <item name="js-from-module-folder" xsi:type="string">
                        Vendor_Module/js/breeze/my-custom-file
                    </item>
                </item>
            </item>
        </argument>
    </arguments>
</referenceBlock>

Keep one of js-from-theme-folder and js-from-theme-folder items depending on your needs.

Create js file. If you use js-from-theme-folder item, the path is <theme>/web/js/breeze/my-custom-file.js. Otherwise, the path is <module>/view/frontend/web/js/breeze/my-custom-file.js.

Theme customization script

This is the easiest way to add custom script to your theme. No need to create layout update file.

Make sure to create and change your theme to Local/breeze-custom before start.

There are two built-in entry points for custom scripts in Breeze theme:

Create [extend|custom].js file in Local/breeze-custom/web/js/breeze folder. This file will be included automatically at all pages.

Example:

(function () {
    'use strict';

    $(document).on('breeze:load', function () {
        console.log('Hello');
    });
})();

Here is how directory structure will look like for Local/breeze-custom theme:

Local/breeze-custom/
├── web/
│   └── js/
│       └── breeze/
│           ├── custom.js
│           └── extend.js
├── composer.json
├── registration.php
└── theme.xml

Miscellaneous HTML

Magento provides two entry points to add your custom HTML code:

Breeze provides lazy script evaluation feature. We recommend to use it when importing third-party service script.

Example:

<script type="lazy">
    console.log('hello');
</script>