001: /*
002: * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.
003: *
004: * Copyright 1997-2007 Sun Microsystems, Inc. All rights reserved.
005: *
006: * The contents of this file are subject to the terms of either the GNU
007: * General Public License Version 2 only ("GPL") or the Common
008: * Development and Distribution License("CDDL") (collectively, the
009: * "License"). You may not use this file except in compliance with the
010: * License. You can obtain a copy of the License at
011: * http://www.netbeans.org/cddl-gplv2.html
012: * or nbbuild/licenses/CDDL-GPL-2-CP. See the License for the
013: * specific language governing permissions and limitations under the
014: * License. When distributing the software, include this License Header
015: * Notice in each file and include the License file at
016: * nbbuild/licenses/CDDL-GPL-2-CP. Sun designates this
017: * particular file as subject to the "Classpath" exception as provided
018: * by Sun in the GPL Version 2 section of the License file that
019: * accompanied this code. If applicable, add the following below the
020: * License Header, with the fields enclosed by brackets [] replaced by
021: * your own identifying information:
022: * "Portions Copyrighted [year] [name of copyright owner]"
023: *
024: * Contributor(s):
025: *
026: * The Original Software is NetBeans. The Initial Developer of the Original
027: * Software is Sun Microsystems, Inc. Portions Copyright 1997-2006 Sun
028: * Microsystems, Inc. All Rights Reserved.
029: *
030: * If you wish your version of this file to be governed by only the CDDL
031: * or only the GPL Version 2, indicate your decision by adding
032: * "[Contributor] elects to include this software in this distribution
033: * under the [CDDL or GPL Version 2] license." If you do not indicate a
034: * single choice of license, a recipient has the option to distribute
035: * your version of this file under either the CDDL, the GPL Version 2 or
036: * to extend the choice of license to its licensees as provided above.
037: * However, if you add GPL Version 2 code and therefore, elected the GPL
038: * Version 2 license, then the option applies only if the new code is
039: * made subject to such option by the copyright holder.
040: */
041: package org.netbeans.modules.j2ee.sun.share.configbean;
042:
043: import java.beans.*;
044:
045: public class EjbRefBeanInfo extends SimpleBeanInfo {
046:
047: /** Return an appropriate icon (currently, only 16x16 color is available)
048: */
049: public java.awt.Image getIcon(int iconKind) {
050: return loadImage("resources/EjbRefIcon16.gif"); // NOI18N
051: }
052:
053: /**
054: * Gets the bean's <code>BeanDescriptor</code>s.
055: *
056: * @return BeanDescriptor describing the editable
057: * properties of this bean. May return null if the
058: * information should be obtained by automatic analysis.
059: */
060: public BeanDescriptor getBeanDescriptor() {
061: BeanDescriptor beanDescriptor = new BeanDescriptor(
062: EjbRef.class,
063: org.netbeans.modules.j2ee.sun.share.configbean.customizers.EjbRefCustomizer.class);//GEN-HEADEREND:BeanDescriptor
064: return beanDescriptor;
065: }
066:
067: /**
068: * Gets the bean's <code>PropertyDescriptor</code>s.
069: *
070: * @return An array of PropertyDescriptors describing the editable
071: * properties supported by this bean. May return null if the
072: * information should be obtained by automatic analysis.
073: * <p>
074: * If a property is indexed, then its entry in the result array will
075: * belong to the IndexedPropertyDescriptor subclass of PropertyDescriptor.
076: * A client of getPropertyDescriptors can use "instanceof" to check
077: * if a given PropertyDescriptor is an IndexedPropertyDescriptor.
078: */
079: public PropertyDescriptor[] getPropertyDescriptors() {
080: int PROPERTY_ejbRefName = 0;
081: int PROPERTY_identity = 1;
082: int PROPERTY_jndiName = 2;
083:
084: PropertyDescriptor[] properties = new PropertyDescriptor[3];
085:
086: try {
087: properties[PROPERTY_ejbRefName] = new PropertyDescriptor(
088: "ejbRefName", EjbRef.class, "getEjbRefName", null);
089: properties[PROPERTY_identity] = new PropertyDescriptor(
090: "identity", EjbRef.class, "getIdentity",
091: "setIdentity");
092: properties[PROPERTY_jndiName] = new PropertyDescriptor(
093: "jndiName", EjbRef.class, "getJndiName",
094: "setJndiName");
095: } catch (IntrospectionException e) {
096: }//GEN-HEADEREND:Properties
097: return properties;
098: }
099:
100: /**
101: * Gets the bean's <code>EventSetDescriptor</code>s.
102: *
103: * @return An array of EventSetDescriptors describing the kinds of
104: * events fired by this bean. May return null if the information
105: * should be obtained by automatic analysis.
106: */
107: public EventSetDescriptor[] getEventSetDescriptors() {
108: int EVENT_propertyChangeListener = 0;
109: int EVENT_vetoableChangeListener = 1;
110: EventSetDescriptor[] eventSets = new EventSetDescriptor[2];
111:
112: try {
113: eventSets[EVENT_propertyChangeListener] = new EventSetDescriptor(
114: org.netbeans.modules.j2ee.sun.share.configbean.EjbRef.class,
115: "propertyChangeListener",
116: java.beans.PropertyChangeListener.class,
117: new String[] { "propertyChange" },
118: "addPropertyChangeListener",
119: "removePropertyChangeListener");
120: eventSets[EVENT_vetoableChangeListener] = new EventSetDescriptor(
121: org.netbeans.modules.j2ee.sun.share.configbean.EjbRef.class,
122: "vetoableChangeListener",
123: java.beans.VetoableChangeListener.class,
124: new String[] { "vetoableChange" },
125: "addVetoableChangeListener",
126: "removeVetoableChangeListener");
127: } catch (IntrospectionException e) {
128: }
129: return eventSets;
130: }
131:
132: /**
133: * Gets the bean's <code>MethodDescriptor</code>s.
134: *
135: * @return An array of MethodDescriptors describing the methods
136: * implemented by this bean. May return null if the information
137: * should be obtained by automatic analysis.
138: */
139: public MethodDescriptor[] getMethodDescriptors() {
140: return new MethodDescriptor[0];
141: }
142: }
|