2005-12-08 07:13:07 +00:00

411 lines
20 KiB
Plaintext

<%--
Copyright (C) 2005 Alfresco, Inc.
Licensed under the Mozilla Public License version 1.1
with a permitted attribution clause. You may obtain a
copy of the License at
http://www.alfresco.org/legal/license.txt
Unless required by applicable law or agreed to in writing,
software distributed under the License is distributed on an
"AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND,
either express or implied. See the License for the specific
language governing permissions and limitations under the
License.
--%>
<%@ taglib uri="http://java.sun.com/jsf/html" prefix="h" %>
<%@ taglib uri="http://java.sun.com/jsf/core" prefix="f" %>
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>
<%@ taglib uri="/WEB-INF/alfresco.tld" prefix="a" %>
<%@ taglib uri="/WEB-INF/repo.tld" prefix="r" %>
<%@ page buffer="64kb" contentType="text/html;charset=UTF-8" %>
<%@ page isELIgnored="false" %>
<r:page>
<f:view>
<%-- load a bundle of properties I18N strings here --%>
<f:loadBundle basename="alfresco.messages.webclient" var="msg"/>
<h:form acceptCharset="UTF-8" id="testForm">
<h2>Components Test Page</h2>
<%-- ModeList tests --%>
<b>ModeList component:</b><br>
Basic ModeList<br>
<a:modeList itemSpacing="2" iconColumnWidth="0"
style="background-color:#EEEEEE" selectedStyle="background-color:#FFFFFF;border:solid #444444;border-width:1px">
<a:listItem value="1" label="First Item" tooltip="Item Number 1" />
<a:listItem value="2" label="Second Item" tooltip="Item Number 2" />
<a:listItem value="3" label="Third Item" tooltip="Item Number 3" />
</a:modeList>
<br>
Modelist with styles applied, icons, title label and the initial value set:<br>
<a:modeList label="Views:" itemSpacing="2" iconColumnWidth="20" width="100"
style="background-color:#F3F1EB" itemStyle="font-family:Tahoma;font-size:11px"
selectedStyle="background-color:#EBF1FF;font-family:Tahoma;font-size:11px;border:solid #4444FF;border-width:1px"
value="1">
<a:listItem value="0" label="None" tooltip="No Icon Here" />
<a:listItem value="1" label="Details" image="/images/icons/BlueArrow.gif" />
<a:listItem value="2" label="Icons" image="/images/icons/BlueArrow.gif" />
<a:listItem value="3" label="List" image="/images/icons/BlueArrow.gif" />
</a:modeList>
<br>
ModeList rendered horizontally with first item selected:<br>
<a:modeList itemSpacing="2" iconColumnWidth="0" horizontal="true" value="1"
style="background-color:#EEEEEE" selectedStyle="background-color:#FFFFFF;border:solid #444444;border-width:1px">
<a:listItem value="1" label="Item 001" tooltip="Item Number 1" />
<a:listItem value="2" label="Item 002" tooltip="Item Number 2" />
<a:listItem value="3" label="Item 003" tooltip="Item Number 3" />
</a:modeList>
<p>
<%-- Menu tests --%>
<b>Menus:</b><br>
Simple menu:<br>
<a:menu id="menu1" menuStyle="background-color:#FFFFFF; border:thin solid #AAAAAA;"
itemSpacing="4" label="Menu" tooltip="I am a menu tooltip">
<a:actionLink value="Item 001" />
<a:actionLink value="Item 002" />
<a:actionLink value="Item 003" />
<a:actionLink value="Should not see this" rendered="false" />
</a:menu>
<p>
Menu with image, styles and actions with icons:<br>
<a:menu id="menu2" styleClass="header" itemSpacing="2" label="More..." image="/images/icons/arrow_expanded.gif" tooltip="Click Me"
menuStyle="background-color:#eeeeee;border-top:thin solid #FFFFFF; border-left:thin solid #FFFFFF; border-right:thin solid #444444; border-bottom:thin solid #444444;">
<a:actionLink value="Menu Action Link" image="/images/icons/BlueArrow.gif" />
<a:actionLink value="Click Me" image="/images/icons/link_small.gif" action="success" actionListener="#{TestList.clickActionLink}" styleClass="header" />
<a:actionLink value="No Image here" />
</a:menu>
<p>
<%-- Breadcrumb tests --%>
<b>Breadcrumbs:</b><br>
Default style with modified separator and actionListener handler:<br>
<a:breadcrumb id="path1" value="/horse/biscuit/flibble/1234" action="success" actionListener="#{TestList.clickBreadcrumb}" separator="~" />
<br>
Path style with default separator:<br>
<a:breadcrumb id="path2" styleClass="path" value="/this/is/a/small/breadcrumb" tooltip="I am a tooltip" />
<br>
Root should be missing from this breadcrumb:<br>
<a:panel id="panelCrumb" progressive="true">
<a:breadcrumb id="path3" styleClass="path" value="/001/002/003/004/005" showRoot="false" />
</a:panel>
<p>
<%-- ActionLink tests --%>
<b>ActionLinks:</b><br>
<a:actionLink id="action1" value="Action Link" action="success" actionListener="#{TestList.clickActionLink}" />
<br>
<a:actionLink id="action2" value="Action Link With CSS" action="success" actionListener="#{TestList.clickActionLink}" styleClass="header" />
<br>
Action link with image and text, using vertical alignment property to centre text.<br>
<a:actionLink id="action3" value="Image Action Link" image="/images/icons/BlueArrow.gif" verticalAlign="40%" />
<br>
Action link with no text, just an image with title/alt text instead:<br>
<a:actionLink id="action4" value="Image Only Action Link" image="/images/icons/link_small.gif" showLink="false"/>
<p>
<%-- Progressive panel tests --%>
<b>Progressive Panels:</b><br>
<a:panel id="panel0" border="ballongrey" bgcolor="#EEEEEE" progressive="true" label="Progressive Panel Test 1" styleClass="mainTitle" expanded="false">
<p>
HTML text inside the Progressive Panel
<p>
<h:outputText id="out1" value="Text From Component with explicit ID"/>
</a:panel>
<br>
<a:panel id="panel1" border="mainwhite" bgcolor="white" progressive="true" label="Progressive Panel Test 2 (SHOULD BREAK WHEN CLOSED)" styleClass="mainTitle">
<p>
nothing exciting here
<b>not at all</b>
<p>
<h:outputText value="Component WITHOUT explicit ID (SHOULD BREAK THE PANEL!)"/>
<br>
<h:commandButton id="panel1-but1" value="Button with explicit ID" action="success" />
</a:panel>
<p>
<%-- RichList component test --%>
<%-- The RichList component is different to the data-grid in that it is
designed to render it's own child components. This means it is capable
of rendering the columns in any order and in any kind of layout. Allowing
the impl of details, icons and list views within a single component. --%>
<%-- NOTE: Suggest config of each view independantly in the config XML e.g.
to allow the icon/details views to use different page sizes or styles.
Otherwise you have to pick values "compatible" with all view modes! --%>
<b>RichList:</b><br>
RichList component test shown in Details view mode, including sortable columns of various data types and paging.<br>
<a:richList viewMode="details" pageSize="5" styleClass="" style="border:thin solid #eeeeff; padding:2px" rowStyleClass="recordSetRow" altRowStyleClass="recordSetRowAlt" width="100%"
value="#{TestList.rows}" var="r" initialSortColumn="name" initialSortDescending="true">
<a:column primary="true" width="200" style="padding:2px" styleClass="">
<f:facet name="header">
<a:sortLink label="Name" value="name" mode="case-insensitive" styleClass="header"/>
</f:facet>
<f:facet name="large-icon">
<%-- this could be a clickable action image etc. --%>
<h:graphicImage alt="#{r.name}" title="#{r.name}" width="38" height="38" url="/images/icons/folder_large.png" />
</f:facet>
<f:facet name="small-icon">
<%-- example of a clickable action image as an icon --%>
<a:actionLink value="#{r.name}" image="/images/icons/folder.gif" actionListener="#{TestList.clickNameLink}" showLink="false">
<f:param name="name" value="#{r.name}" />
</a:actionLink>
</f:facet>
<a:actionLink value="#{r.name}" actionListener="#{TestList.clickNameLink}">
<f:param name="name" value="#{r.name}" />
</a:actionLink>
</a:column>
<a:column>
<f:facet name="header">
<a:sortLink label="Count" value="count" styleClass="header"/>
</f:facet>
<h:outputText value="#{r.count}"/>
</a:column>
<a:column>
<f:facet name="header">
<a:sortLink label="Valid" value="valid" styleClass="header"/>
</f:facet>
<h:outputText value="#{r.valid}"/>
</a:column>
<a:column>
<f:facet name="header">
<a:sortLink label="Relevance" value="relevance" styleClass="header"/>
</f:facet>
<h:outputText value="#{r.relevance}"/>
</a:column>
<a:column>
<f:facet name="header">
<a:sortLink label="Created Date" value="created" styleClass="header"/>
</f:facet>
<h:outputText value="#{r.created}">
<%-- example of a DateTime converter --%>
<%-- can be used to convert both input and output text --%>
<f:convertDateTime dateStyle="short" />
</h:outputText>
</a:column>
<a:column actions="true">
<f:facet name="header">
<h:outputText value="#{msg.actions}"/>
</f:facet>
<h:outputText value="Action | Action | Action"/>
</a:column>
<%-- components other than columns added to a RichList will generally
be rendered as part of the list footer --%>
<a:dataPager/>
</a:richList>
<p>
<a:panel id="panel2" border="white" bgcolor="white" progressive="true" label="Progressive Panel Example 3" styleClass="mainSubTitle">
NOTE: currently all JSF components within a Progressive Panel MUST be given an explicit ID!
<br>
Same list shown in a different view mode (Icons). This mode renderer displays the large icon and renderers in a multi-column format. It also chooses not to display the sort header links.
<a:richList id="list2" viewMode="icons" pageSize="6" styleClass="" style="padding:2px" rowStyleClass="recordSetRow" altRowStyleClass="recordSetRowAlt" width="100%"
value="#{TestList.rows}" var="r" initialSortColumn="name" initialSortDescending="true">
<a:column id="list2-col1" primary="true" width="200" style="padding:2px" styleClass="">
<f:facet name="header">
<a:sortLink id="list2-sort1" label="Name" value="name" mode="case-insensitive" styleClass="header"/>
</f:facet>
<f:facet name="large-icon">
<%-- example of a clickable action image as an icon --%>
<a:actionLink id="list2-img1" value="#{r.name}" image="/images/icons/folder_large.png" actionListener="#{TestList.clickNameLink}" showLink="false">
<f:param id="list2-param1-id" name="name" value="#{r.name}" />
</a:actionLink>
</f:facet>
<f:facet name="small-icon">
<h:graphicImage id="list2-img2" alt="#{r.name}" title="#{r.name}" width="15" height="13" url="/images/icons/folder.gif" />
</f:facet>
<%-- example of a clickable action link item --%>
<a:actionLink id="list2-link1" value="#{r.name}" actionListener="#{TestList.clickNameLink}">
<f:param id="list2-param2-id" name="name" value="#{r.name}" />
</a:actionLink>
</a:column>
<%-- TODO: need some way to allow columns for specific views
<a:column forViewMode="icon">
<h:outputText value="This would be a longer textual description"/>
</a:column>
--%>
<a:column id="list2-col2">
<f:facet name="header">
<a:sortLink id="list2-sort2" label="Count" value="count" styleClass="header"/>
</f:facet>
<h:outputText id="list2-out3" value="Count: #{r.count}"/>
</a:column>
<a:column id="list2-col3">
<f:facet name="header">
<a:sortLink id="list2-sort3" label="Created Date" value="created" styleClass="header"/>
</f:facet>
<h:outputText id="list2-out4" value="Created Date: "/>
<h:outputText id="list2-out5" value="#{r.created}">
<%-- example of a DateTime converter --%>
<%-- can be used to convert both input and output text --%>
<f:convertDateTime dateStyle="short" />
</h:outputText>
</a:column>
<a:column id="list2-col4" actions="true">
<f:facet name="header">
<h:outputText id="list2-out6" value="#{msg.actions}"/>
</f:facet>
<h:outputText id="list2-out7" value="Action | Action | Action"/>
</a:column>
<%-- components other than columns added to a RichList will generally
be rendered as part of the list footer --%>
<a:dataPager id="list2-pager"/>
</a:richList>
</a:panel>
<p>
<a:panel id="panel3" border="innergrey" bgcolor="#e8e8e8" progressive="false" label="Non-progressive Panel" styleClass="mainSubTitle">
<br>
Same list shown in a different view mode (List). This mode displays the small icon and uses single column rendering.<br>
<a:richList viewMode="list" pageSize="5" styleClass="" style="padding:4px" width="100%"
value="#{TestList.rows}" var="r" initialSortColumn="name" initialSortDescending="true">
<a:column primary="true">
<f:facet name="header">
<a:sortLink label="Name" value="name" mode="case-insensitive" styleClass="header"/>
</f:facet>
<f:facet name="large-icon">
<%-- this could be a clickable action image etc. --%>
<h:graphicImage alt="#{r.name}" title="#{r.name}" width="38" height="38" url="/images/icons/folder_large.png" />
</f:facet>
<f:facet name="small-icon">
<%-- this could be a clickable action image etc. --%>
<h:graphicImage alt="#{r.name}" title="#{r.name}" width="15" height="13" url="/images/icons/folder.gif" />
</f:facet>
<a:actionLink value="#{r.name}" actionListener="#{TestList.clickNameLink}">
<f:param id="list-param-id" name="name" value="#{r.name}" />
</a:actionLink>
</a:column>
<a:column>
<f:facet name="header">
<a:sortLink label="Count" value="count" styleClass="header"/>
</f:facet>
<h:outputText value="Count: #{r.count}"/>
</a:column>
<a:column>
<f:facet name="header">
<a:sortLink label="Created Date" value="created" styleClass="header"/>
</f:facet>
<h:outputText value="Created Date: "/>
<h:outputText value="#{r.created}">
<%-- example of a DateTime converter --%>
<%-- can be used to convert both input and output text --%>
<f:convertDateTime dateStyle="short" />
</h:outputText>
</a:column>
<a:column actions="true">
<f:facet name="header">
<h:outputText value="#{msg.actions}"/>
</f:facet>
<h:outputText value="Action | Action | Action"/>
</a:column>
<%-- components other than columns added to a RichList will generally
be rendered as part of the list footer --%>
<a:dataPager/>
</a:richList>
</a:panel>
<p/>
<a:panel id="panel4" expanded="true" progressive="true"
border="white" bgcolor="white" titleBorder="greyround" titleBgcolor="#eaeaea"
label="Bordered Title Area Progressive Panel" styleClass="mainSubTitle">
<h:outputText id="panel4-text" value="The content of a bordered title area"/>
</a:panel>
<p>
<%-- component evaluators --%>
<b>Evaluators:</b><br>
1a. Boolean Evaluator - you should see the next line of text:<br>
<a:booleanEvaluator value="#{TestList.rows != null}">
<h:outputText value="Component inside an evaluator"/>
</a:booleanEvaluator>
<br><br>
1b. Boolean Evaluator - you should <i>not</i> see the next line of text:<br>
<a:booleanEvaluator value="#{TestList.rows == null}">
<h:outputText value="Component inside an evaluator"/>
</a:booleanEvaluator>
<br><br>
2a. Value Set Evaluator - you should see the next line of text:<br>
<a:valueSetEvaluator value="#{TestList.rows}">
<h:outputText value="Component inside an evaluator"/>
</a:valueSetEvaluator>
<br><br>
2b. Value Set Evaluator - you should <i>not</i> see the next line of text:<br>
<a:valueSetEvaluator value="#{null}">
<h:outputText value="Component inside an evaluator"/>
</a:valueSetEvaluator>
<br><br>
3a. String Equals Evaluator - you should see the next line of text:<br>
<a:stringEqualsEvaluator value="some string" condition="some string">
<h:outputText value="Component inside an evaluator"/>
</a:stringEqualsEvaluator>
<br><br>
3b. String Equals Evaluator - you should <i>not</i> see the next line of text:<br>
<a:stringEqualsEvaluator value="some string" condition="some string123">
<h:outputText value="Component inside an evaluator"/>
</a:stringEqualsEvaluator>
<br><br>
Test evaluators around menu actions:<br>
<a:menu id="menuX" menuStyle="background-color:#FFFFFF; border:thin solid #AAAAAA;" itemSpacing="2" label="More...">
<a:actionLink value="You should only see this one item" />
<a:booleanEvaluator value="#{TestList.rows == null}">
<a:actionLink value="You should NOT see this second item" />
</a:booleanEvaluator>
</a:menu>
<p>
<%-- Date Picker Component --%>
<%-- Example of a tag utilising an Input Component with a custom renderer.
The renderer handles encoding and decoding of date values to UI elements --%>
<b>Date Picker:</b><br>
Basic date picker:<br>
<a:inputDatePicker id="date1" value="#{TestList.rows[0].created}" startYear="1996" yearCount="10"/>
<br>
Date Picker with CSS style applied:<br>
<a:inputDatePicker id="date2" startYear="2000" yearCount="5" styleClass="inputField" />
<p>
<h:commandButton id="show-zoo-page" value="Show Zoo" action="showZoo" />
</h:form>
</f:view>
</r:page>