001: package org.tigris.scarab.util;
002:
003: /* ================================================================
004: * Copyright (c) 2000-2002 CollabNet. All rights reserved.
005: *
006: * Redistribution and use in source and binary forms, with or without
007: * modification, are permitted provided that the following conditions are
008: * met:
009: *
010: * 1. Redistributions of source code must retain the above copyright
011: * notice, this list of conditions and the following disclaimer.
012: *
013: * 2. Redistributions in binary form must reproduce the above copyright
014: * notice, this list of conditions and the following disclaimer in the
015: * documentation and/or other materials provided with the distribution.
016: *
017: * 3. The end-user documentation included with the redistribution, if
018: * any, must include the following acknowlegement: "This product includes
019: * software developed by Collab.Net <http://www.Collab.Net/>."
020: * Alternately, this acknowlegement may appear in the software itself, if
021: * and wherever such third-party acknowlegements normally appear.
022: *
023: * 4. The hosted project names must not be used to endorse or promote
024: * products derived from this software without prior written
025: * permission. For written permission, please contact info@collab.net.
026: *
027: * 5. Products derived from this software may not use the "Tigris" or
028: * "Scarab" names nor may "Tigris" or "Scarab" appear in their names without
029: * prior written permission of Collab.Net.
030: *
031: * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED
032: * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
033: * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
034: * IN NO EVENT SHALL COLLAB.NET OR ITS CONTRIBUTORS BE LIABLE FOR ANY
035: * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
036: * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE
037: * GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
038: * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER
039: * IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
040: * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
041: * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
042: *
043: * ====================================================================
044: *
045: * This software consists of voluntary contributions made by many
046: * individuals on behalf of Collab.Net.
047: */
048:
049: /**
050: * A model that provides for an application to present a list of possible
051: * options. Can be used along with a velocity macro to create option tags.
052: *
053: * #macro (option $optionModel)
054: * <option #selected($optionModel.isSelected())
055: * value="$optionModel.Value">$optionModel.Name</option>
056: * #end
057: *
058: * @author <a href="mailto:jmcnally@collab.net">John D. McNally</a>
059: * @version $Id: OptionModel.java 7502 2003-03-28 00:02:24Z jon $
060: */
061: public class OptionModel {
062: private String name;
063: private String value;
064: private boolean selected;
065:
066: public OptionModel() {
067: }
068:
069: public OptionModel(String value, String name) {
070: this (value, name, false);
071: }
072:
073: public OptionModel(int value, String name) {
074: this (String.valueOf(value), name);
075: }
076:
077: public OptionModel(int value, String name, boolean selected) {
078: this (String.valueOf(value), name, selected);
079: }
080:
081: public OptionModel(String value, String name, boolean selected) {
082: this .name = name;
083: this .value = value;
084: this .selected = selected;
085: }
086:
087: /**
088: * Get the name which is useful for ui.
089: * @return value of name.
090: */
091: public String getName() {
092: return name;
093: }
094:
095: /**
096: * Set the name which is useful for ui.
097: * @param v Value to assign to name.
098: */
099: public void setName(String v) {
100: this .name = v;
101: }
102:
103: /**
104: * Get the value used by the application.
105: * @return value of value.
106: */
107: public String getValue() {
108: return value;
109: }
110:
111: /**
112: * Set the value used by the application.
113: * @param v Value to assign to value.
114: */
115: public void setValue(String v) {
116: this .value = v;
117: }
118:
119: /**
120: * Get the value of selected.
121: * @return value of selected.
122: */
123: public boolean isSelected() {
124: return selected;
125: }
126:
127: /**
128: * Set the value of selected.
129: * @param v Value to assign to selected.
130: */
131: public void setSelected(boolean v) {
132: this.selected = v;
133: }
134: }
|