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

src.com.ibm.as400.access.ProductLicenseBeanInfo Maven / Gradle / Ivy

///////////////////////////////////////////////////////////////////////////////
//                                                                             
// JTOpen (IBM Toolbox for Java - OSS version)                              
//                                                                             
// Filename: ProductLicenseBeanInfo.java
//                                                                             
// The source code contained herein is licensed under the IBM Public License   
// Version 1.0, which has been approved by the Open Source Initiative.         
// Copyright (C) 1997-2000 International Business Machines Corporation and     
// others. All rights reserved.                                                
//                                                                             
///////////////////////////////////////////////////////////////////////////////

package com.ibm.as400.access;

import java.awt.Image;
import java.beans.BeanDescriptor;
import java.beans.BeanInfo;
import java.beans.SimpleBeanInfo;
import java.beans.EventSetDescriptor;
import java.beans.PropertyChangeListener;
import java.beans.PropertyDescriptor;

/**
   The IFSFileBeanInfo class provides BeanInfo for IFSFile.
**/
public class ProductLicenseBeanInfo extends SimpleBeanInfo
{
  private static final String copyright = "Copyright (C) 1997-2000 International Business Machines Corporation and others.";

  private final static Class beanClass = ProductLicense.class;
  private static EventSetDescriptor[] events_;
  private static PropertyDescriptor[] properties_;
  private static ResourceBundleLoader rbl_;

  static
  {
    try
    {
      // Define the property descriptors.

      // AS400 object
      PropertyDescriptor property1 =
        new PropertyDescriptor("system", beanClass, "getSystem", "setSystem");
      property1.setBound(true);
      property1.setDisplayName(rbl_.getText("PROP_NAME_SYSTEM"));
      property1.setShortDescription(rbl_.getText("PROP_DESC_SYSTEM"));

      // ProductID
      PropertyDescriptor property2 =
        new PropertyDescriptor("productID", beanClass, "getProductID", "setProductID");
      property2.setBound(true);
      property2.setDisplayName(rbl_.getText("PROP_NAME_LICENSE_PRODUCTID"));
      property2.setShortDescription(rbl_.getText("PROP_DESC_LICENSE_PRODUCTID"));

      // Feature
      PropertyDescriptor property3 =
        new PropertyDescriptor("feature", beanClass, "getFeature", "setFeature");
      property3.setBound(true);
      property3.setDisplayName(rbl_.getText("PROP_NAME_LICENSE_FEATUREID"));
      property3.setShortDescription(rbl_.getText("PROP_DESC_LICENSE_FEATUREID"));

      // Release
      PropertyDescriptor property4 =
        new PropertyDescriptor("releaseLevel", beanClass, "getReleaseLevel", "setReleaseLevel");
      property4.setBound(true);
      property4.setDisplayName(rbl_.getText("PROP_NAME_LICENSE_RELEASELEVEL"));
      property4.setShortDescription(rbl_.getText("PROP_DESC_LICENSE_RELEASELEVEL"));


      /*
      // The introspecition process will reveal features that aren't
      // really properties.  We must declare them and mark as hidden.
      PropertyDescriptor property3 =
        new PropertyDescriptor("absolutePath", beanClass, "getAbsolutePath",
                               null);
      property3.setHidden(true);
      PropertyDescriptor property4 =
        new PropertyDescriptor("canonicalPath", beanClass, "getCanonicalPath",
                               null);
      property4.setHidden(true);
      PropertyDescriptor property5 =
        new PropertyDescriptor("freeSpace", beanClass, "getFreeSpace",
                               null);
      property5.setHidden(true);
      PropertyDescriptor property6 =
        new PropertyDescriptor("name", beanClass, "getName",
                               null);
      property6.setHidden(true);
      PropertyDescriptor property7 =
        new PropertyDescriptor("parent", beanClass, "getParent",
                               null);
      property7.setHidden(true);
      PropertyDescriptor property8 =
        new PropertyDescriptor("absolute", beanClass, "isAbsolute",
                               null);
      property8.setHidden(true);
      PropertyDescriptor property9 =
        new PropertyDescriptor("directory", beanClass, "isDirectory",
                               null);
      property9.setHidden(true);
      PropertyDescriptor property10 =
        new PropertyDescriptor("file", beanClass, "isFile",
                               null);
      property10.setHidden(true);
      PropertyDescriptor property11 =
        new PropertyDescriptor("lastModified", beanClass, null,
                               "setLastModified");
      property11.setHidden(true);

      */

      PropertyDescriptor[] properties = { property1, property2, property3, property4 };
      properties_ = properties;

      // Define the event descriptors.
      EventSetDescriptor event1 =
        new EventSetDescriptor(beanClass, "propertyChange",
                               PropertyChangeListener.class,
                               "propertyChange");
      event1.setShortDescription(rbl_.getText("EVT_DESC_PROPERTY_CHANGE"));
      event1.setDisplayName(rbl_.getText("EVT_NAME_PROPERTY_CHANGE"));
      String[] listenerMethods = { "licenseReleased", "licenseRequested" };

      EventSetDescriptor event2 =
        new EventSetDescriptor(beanClass, "productLicense", ProductLicenseListener.class,
                               listenerMethods, "addProductLicenseListener",
                               "removeProductLicenseListener");
      event2.setDisplayName(rbl_.getText("EVT_NAME_LICENSE_EVENT"));
      event2.setShortDescription(rbl_.getText("EVT_DESC_LICENSE_EVENT"));

      EventSetDescriptor[] events = { event1, event2 };
      events_ = events;
     }
    catch(Exception e)
    {
      throw new Error(e.toString());
    }
  }

  /**
   Returns the bean descriptor.
   @return The bean descriptor.
   **/
  public BeanDescriptor getBeanDescriptor()
  {
    return new BeanDescriptor(beanClass);
  }


  /**
   Returns the default event index.
   @return The default event index (always 1).
   **/
  public int getDefaultEventIndex()
  {
    return 1;
  }

  /**
   Returns the default property index.
   @return The default property index (always 0).
   **/
  public int getDefaultPropertyIndex()
  {
    return 0;
  }

  /**
   Returns the descriptors for all events.
   @return The descriptors for all events.
   **/
  public EventSetDescriptor[] getEventSetDescriptors()
  {
    return events_;
  }

  /**
   Returns the descriptors for all properties.
   @return The descriptors for all properties.
   **/
  public PropertyDescriptor[] getPropertyDescriptors()
  {
    return properties_;
  }

  /**
   Returns an Image for this bean's icon.
   @param icon The desired icon size and color.
   @return The Image for the icon.
   **/
  public Image getIcon(int icon)
  {
    Image image = null;

    switch(icon)
    {
    case BeanInfo.ICON_MONO_16x16:
    case BeanInfo.ICON_COLOR_16x16:
      image = loadImage("License16.gif");
      break;
    case BeanInfo.ICON_MONO_32x32:
    case BeanInfo.ICON_COLOR_32x32:
      image = loadImage("LIcense32.gif");
      break;
    }

    return image;
  }

}





© 2015 - 2025 Weber Informatics LLC | Privacy Policy