All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.apache.juneau.rest.widget.Tooltip Maven / Gradle / Ivy

There is a newer version: 9.0.1
Show newest version
// ***************************************************************************************************************************
// * Licensed to the Apache Software Foundation (ASF) under one or more contributor license agreements.  See the NOTICE file *
// * distributed with this work for additional information regarding copyright ownership.  The ASF licenses this file        *
// * to you 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.apache.juneau.rest.widget;

import static org.apache.juneau.dto.html5.HtmlBuilder.*;

import java.util.*;

import org.apache.juneau.*;
import org.apache.juneau.dto.html5.*;

/**
 * Simple template for adding tooltips to HTML5 bean constructs, typically in menu item widgets.
 *
 * 

* Tooltips depend on the existence of the tooltip and tooltiptext styles that should be * present in the stylesheet for the document. * *

* The following examples shows how tooltips can be added to a menu item widget. * *

* public class MyFormMenuItem extends MenuItemWidget { * * @Override * public String getLabel(RestRequest req) throws Exception { * return "myform"; * } * * @Override * public Object getContent(RestRequest req) throws Exception { * return div( * form().id("form").action("servlet:/form").method(POST).children( * table( * tr( * th("Field 1:"), * td(input().name("field1").type("text")), * td(new Tooltip("(?)", "This is field #1!", br(), "(e.g. '", code("Foo"), "')")) * ), * tr( * th("Field 2:"), * td(input().name("field2").type("text")), * td(new Tooltip("(?)", "This is field #2!", br(), "(e.g. '", code("Bar"), "')")) * ) * ) * ) * ); * } * } *

*/ public class Tooltip { private final String display; private final List content; /** * Constructor. * * @param display * The normal display text. * This is what gets rendered normally. * @param content * The hover contents. * Typically a list of strings, but can also include any HTML5 beans as well. */ public Tooltip(String display, Object...content) { this.display = display; this.content = new ArrayList(Arrays.asList(content)); } /** * The swap method. * *

* Converts this bean into a div tag with contents. * * @param session The bean session. * @return The swapped contents of this bean. */ public Div swap(BeanSession session) { return div( small(display), span()._class("tooltiptext").children(content) )._class("tooltip"); } }