<MyColourRendererPlugin Project>/src/org/myorg/mycolourrendererplugin/ColouringRendererBeanInfo.java
/*
 * To change this template, choose Tools | Templates
 * and open the template in the editor.
 */

package org.myorg.mycolourrendererplugin;

import java.beans.BeanDescriptor;
import java.beans.EventSetDescriptor;
import java.beans.IntrospectionException;
import java.beans.MethodDescriptor;
import java.beans.PropertyDescriptor;
import java.beans.SimpleBeanInfo;
import java.util.logging.Level;
import java.util.logging.Logger;
import org.openide.util.NbBundle;

/**
 *
 */
public class ColouringRendererBeanInfo extends SimpleBeanInfo {

    // Bean descriptor
    /*lazy BeanDescriptor*/
    private static BeanDescriptor getBdescriptor(){
        BeanDescriptor beanDescriptor = new BeanDescriptor  ( ColouringRenderer.class , null ); // NOI18N
        beanDescriptor.setDisplayName(NbBundle.getMessage(ColouringRendererBeanInfo.class, "TIT_ColoringRenderer"));

        // Here you can add code for customizing the BeanDescriptor.

        return beanDescriptor;     }
    

    // Property identifiers
    private static final int PROPERTY_splitValue = 0;
    private static final int PROPERTY_lowerColor = 1;
    private static final int PROPERTY_higherColor = 2;

    // Property array
    /*lazy PropertyDescriptor*/
    private static PropertyDescriptor[] getPdescriptor(){
        PropertyDescriptor[] properties = new PropertyDescriptor[3];

        try {
            properties[PROPERTY_splitValue] = new PropertyDescriptor ( "splitValue", ColouringRenderer.class, "getSplitValue", "setSplitValue" ); // NOI18N
            properties[PROPERTY_splitValue].setDisplayName ( NbBundle.getMessage(ColouringRendererBeanInfo.class, "NAME_SplitValue") );
            properties[PROPERTY_lowerColor] = new PropertyDescriptor ( "lowerColor", ColouringRenderer.class, "getLowerColor", "setLowerColor" ); // NOI18N
            properties[PROPERTY_lowerColor].setDisplayName ( NbBundle.getMessage(ColouringRendererBeanInfo.class,"NAME_LowerColor") );
            properties[PROPERTY_higherColor] = new PropertyDescriptor ( "higherColor", ColouringRenderer.class, "getHigherColor", "setHigherColor" ); // NOI18N
            properties[PROPERTY_higherColor].setDisplayName ( NbBundle.getMessage(ColouringRendererBeanInfo.class,"NAME_HigherColor") );
        }
        catch(IntrospectionException e) {
            Logger.getLogger(ColouringRendererBeanInfo.class.getName()).log(Level.WARNING, null, e);
        }

        // Here you can add code for customizing the properties array.
        //properties[PROPERTY_font].setValue("type", "java.awt.Color"); // NOI18N
        return properties;     }

    // EventSet identifiers

    // EventSet array
    /*lazy EventSetDescriptor*/
    private static EventSetDescriptor[] getEdescriptor(){
        EventSetDescriptor[] eventSets = new EventSetDescriptor[0];

        // Here you can add code for customizing the event sets array.

        return eventSets;     }

    // Method identifiers

    // Method array
    /*lazy MethodDescriptor*/
    private static MethodDescriptor[] getMdescriptor(){
        MethodDescriptor[] methods = new MethodDescriptor[0];

        // Here you can add code for customizing the methods array.

        return methods;     }


    private static final int defaultPropertyIndex = -1;
    private static final int defaultEventIndex = -1;




    // Here you can add code for customizing the Superclass BeanInfo.



    /**
     * Gets the bean's <code>BeanDescriptor</code>s.
     *
     * @return BeanDescriptor describing the editable
     * properties of this bean.  May return null if the
     * information should be obtained by automatic analysis.
     */
    @Override
    public BeanDescriptor getBeanDescriptor() {
        return getBdescriptor();
    }

    /**
     * Gets the bean's <code>PropertyDescriptor</code>s.
     *
     * @return An array of PropertyDescriptors describing the editable
     * properties supported by this bean.  May return null if the
     * information should be obtained by automatic analysis.
     * <p>
     * If a property is indexed, then its entry in the result array will
     * belong to the IndexedPropertyDescriptor subclass of PropertyDescriptor.
     * A client of getPropertyDescriptors can use "instanceof" to check
     * if a given PropertyDescriptor is an IndexedPropertyDescriptor.
     */
    @Override
    public PropertyDescriptor[] getPropertyDescriptors() {
        return getPdescriptor();
    }

    /**
     * Gets the bean's <code>EventSetDescriptor</code>s.
     *
     * @return  An array of EventSetDescriptors describing the kinds of
     * events fired by this bean.  May return null if the information
     * should be obtained by automatic analysis.
     */
    @Override
    public EventSetDescriptor[] getEventSetDescriptors() {
        return getEdescriptor();
    }

    /**
     * Gets the bean's <code>MethodDescriptor</code>s.
     *
     * @return  An array of MethodDescriptors describing the methods
     * implemented by this bean.  May return null if the information
     * should be obtained by automatic analysis.
     */
    @Override
    public MethodDescriptor[] getMethodDescriptors() {
        return getMdescriptor();
    }

    /**
     * A bean may have a "default" property that is the property that will
     * mostly commonly be initially chosen for update by human's who are
     * customizing the bean.
     * @return  Index of default property in the PropertyDescriptor array
     *          returned by getPropertyDescriptors.
     * <P>      Returns -1 if there is no default property.
     */
    @Override
    public int getDefaultPropertyIndex() {
        return defaultPropertyIndex;
    }

    /**
     * A bean may have a "default" event that is the event that will
     * mostly commonly be used by human's when using the bean.
     * @return Index of default event in the EventSetDescriptor array
     *          returned by getEventSetDescriptors.
     * <P>      Returns -1 if there is no default event.
     */
    @Override
    public int getDefaultEventIndex() {
        return defaultEventIndex;
    }
}