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

src.com.ibm.as400.util.servlet.ResourceListMetaData Maven / Gradle / Ivy

///////////////////////////////////////////////////////////////////////////////
//                                                                             
// JTOpen (IBM Toolbox for Java - OSS version)                              
//                                                                             
// Filename: ResourceListMetaData.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.util.servlet;

import com.ibm.as400.util.html.HTMLConstants;

import com.ibm.as400.access.ExtendedIllegalArgumentException;
import com.ibm.as400.access.Trace;
import com.ibm.as400.resource.ResourceList;
import com.ibm.as400.resource.ResourceMetaData;
import com.ibm.as400.resource.ResourceException;
import com.ibm.as400.resource.Presentation;


class ResourceListMetaData implements RowMetaData, java.io.Serializable
{
  static final long serialVersionUID = 773517785366319026L;

   private ResourceList  resourceList_;           // The resource list.
   private Object[]      columnAttributeIDs_;     // The column attributes.
   private String[]      columnLabel_;            // The array of column labels.


    private String[] columnAlignment_;  // The array of column alignments.  @D5A
    private String[] columnDirection_;   // The array of column alignments.  @D5A
   /**
    *  Constructs a default ResourceListMetaData object.
   **/
   public ResourceListMetaData()
   {
      super();
   }


   /**
   *  Constructs a ResourceListMetaData object with the specified resourceList and columnAttributeIDs.
   *  @param resourceList The resource list.
   *  @param columnAttributeIDs The array of column attribute IDs.
   *  @see com.ibm.as400.resource.ResourceList
   **/    
   public ResourceListMetaData(ResourceList resourceList, Object[] columnAttributeIDs)
   {
      this();

      setResourceList(resourceList);
      setColumnAttributeIDs(columnAttributeIDs);

      columnAlignment_ = new String[ getColumnCount() ];
        columnDirection_ = new String[ getColumnCount() ];

   }


   /**
     *  Returns the alignment of the column specified by columnIndex.
     *  @param columnIndex The column index (0-based).
     *  @return The horizontal column alignment.  One of the following constants
     *  defined in HTMLConstants:  LEFT, CENTER, RIGHT, or JUSTIFY.
     *  @see com.ibm.as400.util.html.HTMLConstants
     **/
    public String getColumnAlignment(int columnIndex)      //@D5A
    {
        // Validate the column parameter.
        validateColumnIndex(columnIndex);

        return columnAlignment_[columnIndex];
    }


    /**
    *  Returns the direction of the column specified by columnIndex.
    *  @param columnIndex The column index (0-based).
    *  @return The column direction.
    *  @see com.ibm.as400.util.html.HTMLConstants
    **/
    public String getColumnDirection(int columnIndex)    //@D5A
    {
        // Validate the column parameter.
        validateColumnIndex(columnIndex);

        return columnDirection_[columnIndex];
    }



    /**
    *  Returns the number of columns.
    *  @return The column count.
    **/
   public int getColumnCount()
   {
      return columnAttributeIDs_.length;
   }


   /**
    *  Returns the display size in characters of the column specified by columnIndex.
    *  @param columnIndex The column index (0-based).
    *  @return The column display size in characters.
    **/
   public int getColumnDisplaySize(int columnIndex)
   {
      // Validate the column parameter.
      validateColumnIndex(columnIndex);

      if (columnAttributeIDs_[columnIndex] == null)
         return 20;
      else 
      {
         int dataWidth = 20;
         ResourceMetaData attributeMetaData = resourceList_.getAttributeMetaData(columnAttributeIDs_[columnIndex]);
         Class type = attributeMetaData.getType();
         Presentation[] possibleValuePresentations = attributeMetaData.getPossibleValuePresentations();
         
         // If it is a numeric value, use 10.
         if (Number.class.isAssignableFrom(type))
            dataWidth = 10;
         
         // If it has possible values, use the width of the longest.
         else if (possibleValuePresentations.length > 0) 
         {
            dataWidth = 1;
            for(int i = 0; i < possibleValuePresentations.length; ++i) 
            {
               int nameLength = possibleValuePresentations[i].getName().toString().length();
               if (nameLength > dataWidth)
                  dataWidth = nameLength;
            }
         }
         
         // Make sure its big enough to show the header.
         int nameLength = attributeMetaData.getPresentation().getName().toString().length();
         if (nameLength > dataWidth)
            dataWidth = nameLength;
         
         return dataWidth;
      }
   }


   /**
    *  Returns the label of the column specified by columnIndex.
    *  @param columnIndex The column index (0-based).
    *  @return The column label.
    **/
   public String getColumnLabel(int columnIndex)
   {
      // Validate the column parameter.
      validateColumnIndex(columnIndex);
      
      if (columnLabel_ != null && columnLabel_[columnIndex] != null)
      {  
         return columnLabel_[columnIndex];
      }
      else
      {
         if (columnAttributeIDs_[columnIndex] == null)
         {
            // ResourceBundleLoader_s loader = new ResourceBundleLoader_s();
            return ResourceBundleLoader_s.getText("PROP_NAME_RL_NAME");
         }
         else
            return resourceList_.getAttributeMetaData(columnAttributeIDs_[columnIndex]).getPresentation().getFullName();
      }
   }

   /**
    *  Returns the name of the column specified by columnIndex.
    *  @param columnIndex The column index (0-based).
    *  @return The column name.
    **/
   public String getColumnName(int columnIndex)
   {
      // Validate the column parameter.
      validateColumnIndex(columnIndex);
      
      if (columnAttributeIDs_[columnIndex] != null)
         return resourceList_.getAttributeMetaData(columnAttributeIDs_[columnIndex]).getPresentation().getName();
      else
      {
         // ResourceBundleLoader_s loader = new ResourceBundleLoader_s();
         return ResourceBundleLoader_s.getText("PROP_NAME_RL_NAME");
      }
   }


   /**
    *  Returns the data type of the column specified by columnIndex.
    *  @param columnIndex The column index (0-based).
    *  @return The column RowMetaDataType.
    *  @see com.ibm.as400.util.servlet.RowMetaDataType
    **/
   public int getColumnType(int columnIndex)
   {
      // Validate the column parameter.
      validateColumnIndex(columnIndex);
      
      if (columnAttributeIDs_[columnIndex] == null)
         return RowMetaDataType.STRING_DATA_TYPE;

      Class type = resourceList_.getAttributeMetaData(columnAttributeIDs_[columnIndex]).getType();

      if (type == byte[].class)
         return RowMetaDataType.BYTE_ARRAY_DATA_TYPE;
      else if (type == java.math.BigDecimal.class)
         return RowMetaDataType.BIG_DECIMAL_DATA_TYPE;
      else if ((type == Double.class) || (type == Double.TYPE))
         return RowMetaDataType.DOUBLE_DATA_TYPE;
      else if ((type == Float.class) || (type == Float.TYPE))
         return RowMetaDataType.FLOAT_DATA_TYPE;
      else if ((type == Integer.class) || (type == Integer.TYPE))
         return RowMetaDataType.INTEGER_DATA_TYPE;
      else if ((type == Long.class) || (type == Long.TYPE))
         return RowMetaDataType.LONG_DATA_TYPE;
      else if ((type == Short.class) || (type == Short.TYPE))
         return RowMetaDataType.SHORT_DATA_TYPE;
      else
         return RowMetaDataType.STRING_DATA_TYPE;
   }


   /**
    *  Returns the data type name of the column specified by columnIndex.
    *  @param columnIndex The column index (0-based).
    *  @return The column data type name.
    **/
   public String getColumnTypeName(int columnIndex)
   {
      // Validate the column parameter.
      validateColumnIndex(columnIndex);
      
      return RowMetaDataType.getDataTypeName(getColumnType(columnIndex));
   }

   /**
    *  Returns the precision of the column specified by columnIndex.
    *  This value is not used.  It will always return zero.
    *  @param columnIndex The column index (0-based).
    *  @return The column precision (number of decimal digits).
    **/
   public int getPrecision(int columnIndex)
   {
      // Validate the column parameter.
      validateColumnIndex(columnIndex);
      
      return 0;
   }


   /**
    *  Returns the scale of the column specified by columnIndex.
    *  This value is not used.  It will always return zero.
    *  @param columnIndex The column index (0-based).
    *  @return The column scale (number of digits to the right of the decimal point).
    **/
   public int getScale(int columnIndex)
   {
      // Validate the column parameter.
      validateColumnIndex(columnIndex);
         
      return 0;
   }

   /**
    *  Indicates if the data type is numeric data.
    *  @param columnIndex The column index (0-based).
    *  @return true if numeric data; false otherwise.
    **/
   public boolean isNumericData(int columnIndex)	
   {
      return RowMetaDataType.isNumericData(getColumnType(columnIndex));
   }

   /**
    *  Indicates if the data type is text data.
    *  @param columnIndex The column index (0-based).
    *  @return true if text data; false otherwise.
    **/
   public boolean isTextData(int columnIndex)
   {
      return RowMetaDataType.isTextData(getColumnType(columnIndex));
   }


   /**
    *  Sets the column attribute IDs.
    *  @param columnAttributeIDs The array of column attribute IDs.
    **/
   public void setColumnAttributeIDs(Object[] columnAttributeIDs)
   {
      if (Trace.isTraceOn()) 
         Trace.log(Trace.INFORMATION, "Setting the column attribute IDs.");

      columnAttributeIDs_ = columnAttributeIDs;
   }


   /**
      *  Sets the specified horizontal alignment for the column data specified by columnIndex.
      *  @param columnIndex The column index (0-based).
      *  @param alignment The horizontal column alignment.  One of the following constants
      *  defined in HTMLConstants:  LEFT, CENTER, RIGHT, or JUSTIFY.
      *  @see com.ibm.as400.util.html.HTMLConstants
      **/
    public void setColumnAlignment(int columnIndex, String alignment)    //@D5A
    {
        // Validate the label parameter.
        if (alignment == null)
            throw new NullPointerException("alignment");

        validateColumnIndex(columnIndex);

        // If align is not one of the valid HTMLConstants, throw an exception.
        if ( !(alignment.equals(HTMLConstants.LEFT))  && !(alignment.equals(HTMLConstants.RIGHT)) && !(alignment.equals(HTMLConstants.CENTER)) && !(alignment.equals(HTMLConstants.JUSTIFY)) )
            throw new ExtendedIllegalArgumentException("alignment", ExtendedIllegalArgumentException.PARAMETER_VALUE_NOT_VALID);

        if (columnAlignment_ == null)
            columnAlignment_ = new String[getColumnCount()];

        columnAlignment_[columnIndex] = alignment;
    }

    /**
    *  Sets the specified direction for the column data specified by columnIndex.
    *  @param columnIndex The column index (0-based).
    *  @param dir The column direction.
    *  @see com.ibm.as400.util.html.HTMLConstants
    **/
    public void setColumnDirection(int columnIndex, String dir)         //@D5A
    {
        // Validate the label parameter.
        if (dir == null)
            throw new NullPointerException("dir");

        validateColumnIndex(columnIndex);

        // If direction is not one of the valid HTMLConstants, throw an exception.
        if ( !(dir.equals(HTMLConstants.LTR))  && !(dir.equals(HTMLConstants.RTL)) )
            throw new ExtendedIllegalArgumentException("dir", ExtendedIllegalArgumentException.PARAMETER_VALUE_NOT_VALID);

        if (columnDirection_ == null)
            columnDirection_ = new String[getColumnCount()];

        columnDirection_[columnIndex] = dir;
    }


    /**
    *  Sets the specified label for the column specified by columnIndex.
    *  @param columnIndex The column index (0-based).
    *  @param label The column label.
    **/
   public void setColumnLabel(int columnIndex, String label)
   {
      // Validate the column parameter.
      validateColumnIndex(columnIndex);

      // Validate the label parameter.
      if (label == null) 
         throw new NullPointerException("label");
      
      if (columnLabel_ == null)
         columnLabel_ = new String[getColumnCount()];

      columnLabel_[columnIndex] = label;
   }


   /**
    *  Sets the resource list.
    *  @param resourceList The resource list.
    *  @see com.ibm.as400.resource.ResourceList
    **/
   public void setResourceList(ResourceList resourceList)
   {
      if (Trace.isTraceOn()) 
         Trace.log(Trace.INFORMATION, "Setting the meta resource list.");

      resourceList_ = resourceList;
   }


   /**
    *  Validates the column index.
    *  @param columnIndex The column index (0-based).
    **/
   private void validateColumnIndex(int columnIndex)
   {
      if ( columnIndex < 0 || columnIndex >= columnAttributeIDs_.length ) 
         throw new ExtendedIllegalArgumentException("columnIndex", ExtendedIllegalArgumentException.RANGE_NOT_VALID);   
   }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy