Legacy Knowledge Base
Published Jul. 2, 2025

Resolve liferay-amd-loader errors for themes with React components

Written By

Tony Ng

How To articles are not official guidelines or officially supported documentation. They are community-contributed content and may not always reflect the latest updates to Liferay DXP. We welcome your feedback to improve How To articles!

While we make every effort to ensure this Knowledge Base is accurate, it may not always reflect the most recent updates or official guidelines.We appreciate your understanding and encourage you to reach out with any feedback or concerns.

Legacy Article

You are viewing an article from our legacy "FastTrack" publication program, made available for informational purposes. Articles in this program were published without a requirement for independent editing or verification and are provided"as is" without guarantee.

Before using any information from this article, independently verify its suitability for your situation and project.

Issue

  • liferay-amd-loader errors for themes containing React components can be seen in the browser console:
    • liferay-amd-loader | Errors returned from server for require( ['test-theme/js/controllers/test_controller.es'] ): ["Missing required module 'test-theme/js/controllers/test_controller.es'"]
  • Starting from DXP 7.2, addModule was removed from liferay-amd-loader, which prevents JavaScript files within the theme from being processed.

Environment

  • DXP 7.2
  • DXP 7.3

Resolution

  1. Build a shared bundle with the JS Toolkit that holds all JavaScript files associated with the theme.
  2. Consume this bundle from the .ftl templates invoking Liferay.Loader.require(), after all JavaScript files are moved from the theme to the generated React Widget, for instance: 
    • Liferay.Loader.require(['my-javascript-project@1.0.0/js/test_controller.es']
  3. A React Widget with the Liferay JS toolkit generator will need to be created using the following articles:

Additional Information

Did this article resolve your issue ?

Legacy Knowledge Base