Skip to content

Latest commit

 

History

History
 
 

learn-resources

Folders and files

NameName
Last commit message
Last commit date

parent directory

..
 
 
 
 
 
 
 
 
 
 
 
 

Using liferay-learn:message Tags

You can provide direct links to Liferay Learn documentation from Liferay's UI with the liferay-learn:message tag. For example, the Click to Chat app links to the Chatwoot Liferay Learn article.

The Click to Chat page links to the Chatwoot article.

Now users can click your liferay-learn:message links to get help!

The links have two parts:

  1. A JSON file specifying the linked documentation.

  2. A liferay-learn:message tag pointing to the JSON file and one of its links.

Keeping the resources separate from your JSP code makes it easier to update link labels and URLs and add translations.

Note: This is safe to use: the liferay-learn:message tag renders nothing if you accidentally reference a missing JSON file or an unspecified resource entry.

Start with specifying a resource.

Adding Resources in a JSON File

  1. In this folder (learn-resources), create a JSON file named after your module.

  2. Create an element for each resource on Liferay Learn. For example, the learn-resources/data/marketplace-store-web.json file has these resource entries:

    {
    	"download-app": { // Resource key
    		"en_US": {
    			"message": "How can I download an app?", // Link label
    			"url": "https://learn.liferay.com/dxp/latest/en/system-administration/installing-and-managing-apps/installing-apps/downloading-apps.html" // Resource URL
    		}
    	},
    	"purchase-app": {
    		"en_US": {
    			"message": "How can I purchase an app?",
    			"url": "https://learn.liferay.com/dxp/latest/en/system-administration/installing-and-managing-apps/getting-started/using-marketplace.html"
    		}
    	}
    }

The example resource entries have the keys download-app and purchase-app. The keys are unique within the JSON file. You can provide each resource in multiple locales. For example, the resources above are in the en_US locale. For each locale, assign the url to the resource location and the message to a label for the resource link.

Note: The only valid locales on Liferay Learn are en-US and ja-JP.

Adding liferay-learn:message Tags to a JSP

In your module's JSP, link to the resources using liferay-learn:message tags. For example, use this code in the marketplace-store-web module's view.jsp file to reference the learn-resources/data/marketplace-store-web.json file's download-app resource:

<%@ taglib uri="http://liferay.com/tld/learn" prefix="liferay-learn" %>

<liferay-learn:message
    key="download-app"
    resource="marketplace-store-web"
/>

The first line above includes the liferay-learn tag library. The liferay-learn:message tag links to the download-app resource in the learn-resources/data/marketplace-store-web.json file. When the JSP renders, the text How can I download an app? links to the resource located at https://learn.liferay.com/dxp/latest/en/system-administration/installing-and-managing-apps/installing-apps/downloading-apps.html.

That's how you link to Liferay Learn resources!

A CDN server hosts the JSON files. For example, here's how the <liferay-learn:message key="download-app" resource="marketplace-store-web" /> tag works:

  1. The tag checks for the resource file (JSON file with prefix marketplace-store-web) on the local CDN server at https://learn-resources.liferay.com/marketplace-store-web.json.
  2. The local server checks the global server at http://s3.amazonaws.com/learn-resources.liferay.com/marketplace-store-web.json for updates to the resource.
  3. If the local resource is valid, it's served immediately. Otherwise, the local server serves the resource after refreshing the local resource cache with the latest update from the global server.

Note: The cache refreshes every four hours by default, per the learn.resources.refresh.time portal property.

Previewing Liferay Learn Resource Links

If you want to test your link, you don't have to recompile your module. From this folder (learn-resources), you can run a quick dev server that's configured with only one portal property/environment variable:

learn.resources.mode=dev|off|on

or

LIFERAY_LEARN_PERIOD_RESOURCES_PERIOD_MODE=dev|off|on

Use the property with a local bundle and the environment variable with Docker.

dev: Set this value and then run docker compose up from the learn-resources folder to start a small dev server. You can then access <http://localhost:3062/[json file name]> to access your resources. For example, if you're modifying server-admin-web.json, access http://localhost:3062/server-admin-web.json.

on: Set this value to read Learn resources from https://s3.amazonaws.com/learn-resources.liferay.com.

off: Set this value to disable the Learn tag library.

Adding a Resource Link to a React Component

To use the search-experiences-web.json file's advanced-configuration resource key,

  1. In the JSP, use the LearnMessageUtil.getReactDataJSONObject Java method to retrieve the resource data to pass into the React component.

    <%@ page import="com.liferay.learn.LearnMessageUtil" %>
    
    <react:component
    	module='path/to/component'
    	props='<%=
    		HashMapBuilder.<String, Object>put(
    			"learnResources", LearnMessageUtil.getReactDataJSONObject("search-experiences-web")
    		).build()
    	%>'
    />

    To retrieve multiple resources, a string array can be passed into getReactDataJSONObject. For example: LearnMessageUtil.getReactDataJSONObject(new String[] {"portal-search-web", "search-experiences-web"})

  2. In the React component, use LearnResourcesContext to provide the resource and the LearnMessage component to display the link.

    import {LearnMessage, LearnResourcesContext} from 'frontend-js-components-web';
    
    <LearnResourcesContext.Provider value={learnResources}>
    	<LearnMessage
    		resource='search-experiences-web'
    		resourceKey='advanced-configuration'
    	/>
    </LearnResourcesContext.Provider>

    The LearnMessage component renders a ClayLink and additional props are passed into it.

Guidelines

Here are some guidelines for writing the JSON files and tags.

Name the JSON Files After the Web Modules That Use the Resources

For example, if you want the foo-web module's JSPs to link to resources, create the resources in a JSON file called liferay-resources/foo-web.json.

Make Resource Keys Unique Per JSON File

Don't duplicate resource keys in the same JSON file.

Name Lone Resource Keys general

If a JSON file has only one resource key, name the key general.