blob: d746c733a4d84b523b4b7467b546d97ba5dbe4ba [file] [log] [blame]
/*
* 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.click.control;
import java.io.Serializable;
import java.util.ArrayList;
import java.util.List;
import org.apache.click.util.HtmlStringBuffer;
/**
* Provides a select Option Group element:   <optgroup></optgroup>.
* <p/>
* The OptionGroup class uses an immutable design so Option instances can be
* shared by multiple Pages in the multi-threaded Servlet environment.
* This enables OptionGroup instances to be cached as static variables.
* <p/>
* For an OptionGroup code example see the {@link Option} Javadoc example.
* <p/>
* See also the W3C HTML reference:
* <a class="external" target="_blank" title="W3C HTML 4.01 Specification"
* href="http://www.w3.org/TR/html401/interact/forms.html#h-17.6">OPTGROUP</a>
*
* @see Select
* @see Option
*/
public class OptionGroup implements Serializable {
private static final long serialVersionUID = 1L;
// ------------------------------------------------- Instance Variables
/** The groups child Option/OptGroup objects. */
protected List children = new ArrayList();
/** The label for the OptionGroup. */
protected final String label;
// ------------------------------------------------------- Constructors
/**
* Create an OptionGroup with the given display label.
*
* @param label the display label for the OptionGroup
*/
public OptionGroup(String label) {
this.label = label;
}
// -------------------------------------------------- Public Attributes
/**
* Return the OptionGroup's html tag: <tt>optgroup</tt>.
*
* @return the OptionGroup's html tag
*/
public String getTag() {
return "optgroup";
}
/**
* Add the given Option or OptionGroup object to this group.
*
* @param object the Option or OptionGroup to add
*/
public void add(Object object) {
getChildren().add(object);
}
/**
* Return the OptionGroup children.
*
* @return the OptionGroup children
*/
public List getChildren() {
return children;
}
/**
* Return the display label.
*
* @return the display label
*/
public String getLabel() {
return label;
}
// ----------------------------------------------------- Public Methods
/**
* Return a HTML rendered Option string.
*
* @param select the parent Select
* @param buffer the specified buffer to render to
*/
public void render(Select select, HtmlStringBuffer buffer) {
buffer.elementStart(getTag());
buffer.appendAttribute("label", getLabel());
buffer.closeTag();
List list = getChildren();
for (int i = 0, size = list.size(); i < size; i++) {
Object object = list.get(i);
if (object instanceof Option) {
Option option = (Option) object;
option.render(select, buffer);
} else if (object instanceof OptionGroup) {
OptionGroup optionGroup = (OptionGroup) object;
optionGroup.render(select, buffer);
} else {
String msg = "Select option class not instance of Option"
+ " or OptionGroup: " + object.getClass().getName();
throw new IllegalArgumentException(msg);
}
}
buffer.elementEnd(getTag());
}
/**
* Return a HTML rendered OptionGroup string.
*
* @deprecated use {@link #render(org.apache.click.control.Select, org.apache.click.util.HtmlStringBuffer)}
* instead
*
* @param select the parent Select
* @return a rendered HTML OptionGroup string
*/
public String renderHTML(Select select) {
HtmlStringBuffer buffer = new HtmlStringBuffer();
render(select, buffer);
return buffer.toString();
}
}