« Back to Development

Creating Tabs in Liferay Portlets

Introduction #

The Liferay "Journal" portlet, has "Articles,Structures,Templates,Recent" tabs inside the portlet. Liferay includes a custom tab tag which allows you to create the same effect in your own portlets. These tabs are essentially just other .jsp pages that are displayed based on the selection of the tab.

In this article, we will modify the Reports Portlet to have tabs. We will create "Sample Tab 1", "Sample Tab 2" and "Sample Tab 3" tabs. In the end, we will have a portlet that will look something like this:

Create Files #

To do this in your own portlet you will need to create the following files:

Create Tab Pages #

Remember to include some plain text in each file

ext/ext-web/docroot/html/portlet/ext/reports/sample_tab_1.jsp:

sample 1
ext/ext-web/docroot/html/portlet/ext/reports/sample_tab_2.jsp:
sample 2
ext/ext-web/docroot/html/portlet/ext/reports/sample_tab_3.jsp:
sample 3

init.jsp #

in init.jsp include the following code:

ext/ext-web/docroot/html/portlet/ext/reports/init.jsp:

<%@ include file="/html/common/init.jsp" %>

<portlet:defineObjects />

view.jsp #

in view.jsp

ext/ext-web/docroot/html/portlet/ext/reports/view.jsp:

<%@ include file="/html/portlet/ext/reports/init.jsp" %>


<%
String tabs1 = ParamUtil.getString(request, "tabs1", "Sample Tab 1");

PortletURL portletURL = renderResponse.createRenderURL();

portletURL.setWindowState(WindowState.NORMAL);

portletURL.setParameter("struts_action", "/ext/reports/view_reports");
portletURL.setParameter("tabs1", tabs1);

String tabNames = "Sample Tab 1,Sample Tab 2,Sample Tab 3";

%>

<liferay-ui:tabs
   names="<%= tabNames %>"
   url="<%= portletURL.toString() %>"
/>

It is recommeded using "<liferay-util:include page>" instead of "<%@ include file= "

<c:if test='<%= tabs1.equals("Sample Tab 1") %>'>
  <liferay-util:include page="/html/portlet/ext/reports/sample_tab_1.jsp" >
</c:if>
<c:if test='<%= tabs1.equals("Sample Tab 2") %>'>
  <liferay-util:include page="/html/portlet/ext/reports/sample_tab_2.jsp" >
</c:if>
<c:if test='<%= tabs1.equals("Sample Tab 3") %>'>
  <liferay-util:include page="/html/portlet/ext/reports/sample_tab_3.jsp" >
</c:if>

explained:

<%
String tabs1 = ParamUtil.getString(request, "tabs1", "Sample Tab 1");

PortletURL portletURL = renderResponse.createRenderURL();

portletURL.setWindowState(WindowState.NORMAL);

portletURL.setParameter("struts_action", "/ext/reports/view_reports");
portletURL.setParameter("tabs1", tabs1);

String tabNames = "Sample Tab 1,Sample Tab 2,Sample Tab 3";

%>

tabs1: holds the value of the tab to be displayed

tabNames: comma delimited list of tab names

(Note: A common mistake is to include spaces before or after the commas. Make sure there are no extra spaces in the variable "tabNames", otherwise the strings wont match with the value in "tabs1". see above)

<liferay-ui:tabs
   names="<%= tabNames %>"
   url="<%= portletURL.toString() %>"
/>

This is a custom Liferay tab tag. This auto-genereates the tabs based on the variables defined above. (defined: "portal\portal-web\docroot\html\taglib\ui\tabs")

<c:if test='<%= tabs1.equals("Sample Tab 1") %>'>
   <liferay-util:include page="/html/portlet/ext/reports/sample_tab_1.jsp" >
</c:if>
<c:if test='<%= tabs1.equals("Sample Tab 2") %>'>
   <liferay-util:include page="/html/portlet/ext/reports/sample_tab_2.jsp" >
</c:if>
<c:if test='<%= tabs1.equals("Sample Tab 3") %>'>
   <liferay-util:include page="/html/portlet/ext/reports/sample_tab_3.jsp" >
</c:if>

Based on the value of tabs1, this will include a different jsp page.

Deploy your code and now take a look at your Reports Portlet. Now your Reports Portlet should look like:

Make page refresh optional #

Use this snippet to do the same thing without requiring page refreshes.

<liferay-ui:tabs
	names="Sample Tab 1, Sample Tab 2, Sample Tab 3"
	refresh="<%= false %>"
>
	<liferay-ui:section>
		sample 1
	</liferay-ui:section>
	<liferay-ui:section>
		sample 2
	</liferay-ui:section>
	<liferay-ui:section>
		sample 3
	</liferay-ui:section>
</liferay-ui:tabs>
0 Attachments
31292 Views
Average (1 Vote)
Comments

Showing 12 Comments

Rohit Rai
1/23/09 11:49 PM

<liferay-ui:tabs
names="Sample Tab 1,Sample Tab 2,Sample Tab 3"
refresh="<%= false %>"
>
<liferay-ui:section>
sample 1
</liferay-ui:section>
<liferay-ui:section>
sample 2
</liferay-ui:section>
<liferay-ui:section>
sample 3
</liferay-ui:section>
</liferay-ui:tabs>

This code doesn't work for me. The UI is created, but clicking on the tabs deosn't work.
It works if I remove the spaces IN the tab names. Can't we have tabs with two word names?

mipih faical
6/15/09 7:02 AM

hye,
I did the same steps to have some tabs in my portlet but it don't work.
I have the same think in all my tabs.
Can you help me please

Secret Developer
7/30/09 1:21 PM

How can I do this in navigation.vm????

Jeff Goodwin
8/14/09 6:39 PM

Has anyone resolved the issue with spaces in tab names?

JP O
8/23/09 9:55 PM

Hi ppl,

Try using language keys as the tab names and then add to language-ext.properties.
now if you try to add "sign-in" as a tab, you'll see it actually displayed as "Sign In".
Enjoy!

JP O
8/23/09 10:04 PM

0

Muhammed Shakir AK Misarwala
7/19/10 8:47 AM

liferay-ui:util does not work with jsp in custom portlet with expected behavior.

Linh Nguyen
5/8/11 4:39 AM

I got an error in code
<liferay-util:include page="/sample_tab_1.jsp" >
It should be like this
<liferay-util:include page="/sample_tab_1.jsp" servletContext="<%=this.getServletContext() %>"/>

Im using Lifery 6.0.5 and tomcat 6.0.26

Furthermore, you probably need to add taglib in sourcecode to make it work.
like
<%@ taglib uri="/WEB-INF/tld/liferay-ui.tld" prefix="liferay-ui" %>
<%@ taglib uri="/WEB-INF/tld/liferay-util.tld" prefix="liferay-util" %>

which works in my case.

Rohit Salecha
5/24/11 1:38 AM

for more Liferay Tabs

http://liferaydemystified.blogspot.com/2011/05/liferay-ui-tabs.html

Hajri Mohamed
6/9/11 5:51 AM

can we use liferay ui tab inside another liferay ui tab (nested liferay tabs), i m trying but i m having a null pointer exeption

ankit yakkundi
7/14/11 3:58 AM

how to hide/show the tabs using conditions??
ie if some condition gets satisfies then i want to hide some tabs and show some tabs.
how to implement that??

Ram Manusani
12/27/11 11:16 PM

Displaying text on clicking on the tabs works fine with me... Is there a way to show portlets on clicking the tabs??

Any solution will be greatly appreciated