org.icefaces.ace.component.tooltip.TooltipMeta Maven / Gradle / Ivy
Show all versions of icefaces-ace Show documentation
/*
* Copyright 2004-2014 ICEsoft Technologies Canada Corp.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the
* License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* 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.
*/
package org.icefaces.ace.component.tooltip;
import org.icefaces.ace.meta.annotation.*;
import org.icefaces.ace.meta.baseMeta.UIOutputMeta;
import org.icefaces.ace.resources.ACEResourceNames;
import org.icefaces.resources.ICEResourceDependencies;
import org.icefaces.resources.ICEResourceDependency;
import org.icefaces.resources.ICEResourceLibrary;
import javax.el.MethodExpression;
import javax.el.ValueExpression;
@Component(
tagName = "tooltip",
componentClass = "org.icefaces.ace.component.tooltip.Tooltip",
rendererClass = "org.icefaces.ace.component.tooltip.TooltipRenderer",
generatedClass = "org.icefaces.ace.component.tooltip.TooltipBase",
extendsClass = "javax.faces.component.UIOutput",
componentType = "org.icefaces.ace.component.Tooltip",
rendererType = "org.icefaces.ace.component.TooltipRenderer",
componentFamily = "org.icefaces.ace.Tooltip",
tlddoc = "The Tooltip is a component that displays a tooltip with various events, effects and customization options." +
"For more information, see the Tooltip Wiki Documentation."
)
@ICEResourceLibrary(ACEResourceNames.ACE_LIBRARY)
@ICEResourceDependencies({
@ICEResourceDependency(name = "util/ace-core.js"),
@ICEResourceDependency(name = "jquery/jquery.js"),
@ICEResourceDependency(name = "tooltip/jquery.qtip-2.0.0.js"),
@ICEResourceDependency(name = "tooltip/tooltip.js")
})
@ClientBehaviorHolder(events = {
@ClientEvent(name="display", javadoc="Fired before the tooltip is shown (default event).", tlddoc="Fired before the tooltip is shown (default event).", defaultRender="@all", defaultExecute="@this")
}, defaultEvent="display")
public class TooltipMeta extends UIOutputMeta {
@Property(tlddoc="Boolean value specifying whether to create tooltips for all elements with a title attribute using the title attribute value. If explicit content is nested inside this component's tag, that content will be displayed instead of each element's respective title attributes' values.", defaultValue="false")
private boolean global;
@Property(tlddoc="The corner of the target element by which to position the tooltip by. E.g. topLeft, bottomRight. See positioning for all possible values.", defaultValue="bottomRight")
private String targetPosition;
@Property(tlddoc="The corner of the tooltip to position in relation to the target's corner. E.g. topLeft, bottomRight. See positioning for all possible values.", defaultValue="topLeft")
private String position;
@Property(tlddoc="Event which will trigger the showing of the tooltip. Possible values are DOM events, such as \"mouseover\", documented under jQuery's Event: bind().", defaultValue="mouseover")
private String showEvent;
@Property(tlddoc="Time in milliseconds by which to delay the showing of the tooltip.", defaultValue="140")
private int showDelay;
@Property(tlddoc="Effect to use upon showing the tooltip e.g. fade, slide or grow.", defaultValue="fade")
private String showEffect;
@Property(tlddoc="Length of time in milliseconds the show effect will last for.", defaultValue="500")
private int showEffectLength;
@Property(tlddoc="Event which will trigger the hiding of the tooltip. Possible values are DOM events, such as \"mouseout\", documented under jQuery's Event: bind().", defaultValue="mouseout")
private String hideEvent;
@Property(tlddoc="Time in milliseconds by which to delay the hiding of the tooltip.", defaultValue="0")
private int hideDelay;
@Property(tlddoc="Effect to use upon hiding the tooltip e.g. fade, slide or grow.", defaultValue="fade")
private String hideEffect;
@Property(tlddoc="Length of time in milliseconds the hide effect will last for.", defaultValue="500")
private int hideEffectLength;
@Property(name="for", tlddoc="Specifies the id of the component that will display the tooltip. Ignored if \"global\" is true. Multiple component ids can be specified separated by commas.")
private String forValue;
@Property(tlddoc="Specifies the id of the HTML element that will display the tooltip. Applicable only if \"for\" component is not specified. Ignored if \"global\" is true.")
private String forElement;
@Property(tlddoc="Specifies the id of the component that contains the component referenced by the \"for\" attribute. This is to be used in cases where the target component is inside an iterative container such as a data table and the tooltip component itself is outside. A more robust solution is to use \"forDelegate\" instead of this attribute.")
private String forContainer;
@Property(tlddoc="Specifies the id of the component that will receive the tooltip listeners on behalf of the component specified in the \"for\" attribute. This is useful when the tooltip component is outside a data table or iterative container and references a component inside such container. This improves performance by avoiding the creation of tooltip objects in each each row. It also guards against dynamic updates that could replace the component and make it lose its tooltip listeners. Additionally, this method allows retrieving row data by using the \"fetch\" and \"store\" attributes. This is a better alternative to \"forContainer\".")
private String forDelegate;
@Property(tlddoc="The result of evaluating the expression specified in \"fetch\" is stored in the bean property specified in this attribute.")
private Object store;
@Property(tlddoc="When using \"forDelegate\", an EL expression can be specified as the value of this attribute. Such expression will be evaluated at the same point (e.g. row) where the component that triggered the tooltip is located, allowing to retrieve row data in a table or iterative container. The result is saved in the bean property specified by the \"store\" attribute.", expression = Expression.VALUE_EXPRESSION)
private ValueExpression fetch;
@Property(expression = Expression.METHOD_EXPRESSION,
tlddoc = "A server side listener to be invoked when the tooltip is about to be shown in the client. It must evaluate to a public void method with no arguments.")
private MethodExpression displayListener;
@Property(expression = Expression.METHOD_EXPRESSION, methodExpressionArgument = "org.icefaces.ace.event.TooltipDelegateDisplayEvent",
tlddoc = "A server side listener to be invoked when a tooltip in delegate mode is about to be shown in the client. It must evaluate to a public void method with a TooltipDelegateDisplayEvent argument. This listener allows the possiblity of preventing the tooltip from being displayed by calling event.cancelDisplay().")
private MethodExpression delegateDisplayListener;
@Property(tlddoc="Specifies whether the tooltip should be stylized as a speech bubble (i.e. with a speech bubble arrow tip pointing to the triggerer element).", defaultValue="false")
private boolean speechBubble;
@Property(tlddoc="The CSS style class of the component, rendered on the root div of the component.")
private String styleClass;
@Property(tlddoc="The inline style of the component, rendered on the root div of the component.")
private String style;
@Field(defaultValue = "false", defaultValueIsStringLiteral = false)
protected Boolean cancelDisplay;
}