src.com.ibm.as400.vaccess.VSystemValueList Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of jt400 Show documentation
Show all versions of jt400 Show documentation
The Open Source version of the IBM Toolbox for Java
///////////////////////////////////////////////////////////////////////////////
//
// JTOpen (IBM Toolbox for Java - OSS version)
//
// Filename: VSystemValueList.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.vaccess;
import com.ibm.as400.access.AS400;
import com.ibm.as400.access.SystemValueList;
import com.ibm.as400.access.SystemValue;
import javax.swing.Icon;
import java.beans.VetoableChangeListener;
import java.beans.PropertyChangeListener;
import java.beans.PropertyVetoException;
import javax.swing.table.TableColumnModel;
import java.io.ObjectInputStream;
import javax.swing.tree.TreeNode;
import javax.swing.table.DefaultTableColumnModel;
import javax.swing.table.TableCellRenderer;
import javax.swing.table.TableColumn;
import java.util.Enumeration;
/**
* The VSystemValueList class defines the representation of a
* system value list in a system for use in various models
* and panes in this package.
* You must explicitly call load() to load the information from
* the system.
*
* Most errors are reported as ErrorEvents rather than
* throwing exceptions. Users should listen for ErrorEvents
* in order to diagnose and recover from error conditions.
*
*
VSystemValueList objects generate the following events:
*
* - ErrorEvent
*
- PropertyChangeEvent
*
- VObjectEvent
*
- WorkingEvent
*
@deprecated Use Java Swing instead, along with the classes in package com.ibm.as400.access
**/
public class VSystemValueList implements VNode, java.io.Serializable
{
private static final String copyright = "Copyright (C) 1997-2000 International Business Machines Corporation and others.";
// Properties.
private SystemValueList systemValueList_;
private VNode parent_;
// Private data.
private transient VNode[] children_; // These are VSystemValueGroups
// Event support.
private transient ErrorEventSupport errorEventSupport_;
private transient PropertyChangeSupport propertyChangeSupport_;
private transient VetoableChangeSupport vetoableChangeSupport_;
private transient VObjectEventSupport objectEventSupport_;
private transient WorkingEventSupport workingEventSupport_;
// Static data.
private static String description_;
private static Icon icon16_;
private static Icon icon32_;
private static TableColumnModel detailsColumnModel_;
private static String nameColumnHeader_;
private static String descriptionColumnHeader_;
// MRI
final private static String groupName_;
final private static String groupDescription_;
final private static int groupCount_ = SystemValueList.getGroupCount();
static
{
description_ = (String)ResourceLoader.getText("SYSTEM_VALUE_LIST_DESCRIPTION");
groupName_ = (String)ResourceLoader.getText("COLUMN_GROUP");
groupDescription_= (String)ResourceLoader.getText("COLUMN_DESCRIPTION");
icon16_= ResourceLoader.getIcon("VSystemValueList16.gif", description_);
icon32_= ResourceLoader.getIcon("VSystemValueList32.gif", description_);
nameColumnHeader_ = groupName_;
descriptionColumnHeader_ = groupDescription_;
detailsColumnModel_= new DefaultTableColumnModel();
int i= 0;
// These are the columns to display for the children.
// The children are VSystemValueGroups.
// Name Column
VTableColumn vTable1= new VTableColumn(i++, NAME_PROPERTY);
vTable1.setCellRenderer(((TableCellRenderer)new VObjectCellRenderer()));
vTable1.setHeaderRenderer(((TableCellRenderer)new VObjectHeaderRenderer()));
vTable1.setHeaderValue(nameColumnHeader_);
vTable1.setPreferredCharWidth(10);
detailsColumnModel_.addColumn(((TableColumn)vTable1));
// Description Column
VTableColumn vTable2= new VTableColumn(i++, DESCRIPTION_PROPERTY);
vTable2.setCellRenderer(((TableCellRenderer)new VObjectCellRenderer()));
vTable2.setHeaderRenderer(((TableCellRenderer)new VObjectHeaderRenderer()));
vTable2.setHeaderValue(descriptionColumnHeader_);
vTable2.setPreferredCharWidth(40);
detailsColumnModel_.addColumn(((TableColumn)vTable2));
}
/**
* Constructs a VSystemValueList object.
**/
public VSystemValueList()
{
systemValueList_ = new SystemValueList();
initializeTransient();
}
/**
* Constructs a VSystemValueList object.
* @param system The system.
**/
public VSystemValueList(AS400 system)
{
systemValueList_ = new SystemValueList(system);
initializeTransient();
}
/**
* Constructs a VSystemValueList object.
* @param parentNode The parent node.
* @param system The system.
**/
public VSystemValueList(VNode parentNode, AS400 system)
{
if (parentNode == null)
throw new NullPointerException("parent");
systemValueList_ = new SystemValueList(system);
parent_ = parentNode;
initializeTransient();
}
/**
* Adds a listener to be notified when an error occurs.
* @param listener The listener.
**/
public void addErrorListener(ErrorListener listener)
{
errorEventSupport_.addErrorListener(listener);
}
/**
* Adds a listener to be notified when the value of any bound
* property changes.
* @param listener The listener.
**/
public void addPropertyChangeListener(PropertyChangeListener listener)
{
propertyChangeSupport_.addPropertyChangeListener(listener);
}
/**
* Adds a listener to be notified when the value of any constrained
* property changes.
* @param listener The listener.
**/
public void addVetoableChangeListener(VetoableChangeListener listener)
{
vetoableChangeSupport_.addVetoableChangeListener(listener);
}
/**
* Adds a listener to be notified when a VObject is changed,
* created, or deleted.
* @param listener The listener.
**/
public void addVObjectListener(VObjectListener listener)
{
objectEventSupport_.addVObjectListener(listener);
}
/**
* Adds a listener to be notified when work starts and stops
* on potentially long-running operations.
* @param listener The listener.
**/
public void addWorkingListener(WorkingListener listener)
{
workingEventSupport_.addWorkingListener(listener);
}
/**
* Returns the children of the node.
*
* @return The children.
**/
public Enumeration children()
{
return (Enumeration)(new VEnumeration(this));
}
/**
* Returns the list of actions that can be performed.
*
* @return Always null. There are no actions.
*
**/
public VAction[] getActions()
{
return null;
}
/**
* Indiciates if the node allows children.
*
* @return Always true.
**/
public boolean getAllowsChildren()
{
return true;
}
/**
* Returns the child node at the specified index.
*
* @param index The index.
* @return The child node at the specified index.
**/
public TreeNode getChildAt(int index)
{
if (index < 0 || index >= children_.length)
{
return null;
}
return (TreeNode)children_[index];
}
/**
* Returns the number of the children.
*
* @return The number of the children.
**/
public int getChildCount()
{
return children_.length;
}
/**
* Returns the default action.
*
* @return Always null. There is no default action.
**/
public VAction getDefaultAction()
{
return null;
}
/**
* Returns the child for the details at the specified index.
*
* @param index The index.
* @return The child, or null if the index is not
* valid.
**/
public VObject getDetailsChildAt(int index)
{
if (index < 0 || index >= children_.length)
{
return null;
}
return children_[index];
}
/**
* Returns the number of children for the details.
*
* @return The number of children for the details.
**/
public int getDetailsChildCount()
{
return children_.length;
}
/**
* Returns the table column model to be used in the details
* when representing the children. This column model
* describes the details values for the children.
*
* @return The details column model.
**/
public TableColumnModel getDetailsColumnModel()
{
return detailsColumnModel_;
}
/**
* Returns the index of the specified child for the details.
*
* @param detailsChild The details child.
* @return The index, or -1 if the child is not found
* in the details.
**/
public int getDetailsIndex(VObject detailsChild)
{
for (int i=0; i < groupCount_; i++)
{
if (children_[i] == detailsChild)
{
return i;
}
}
return -1;
}
/**
* Returns the icon.
*
* @param size The icon size, either 16 or 32. If any other
* value is given, then returns a default.
* @param open This parameter has no effect.
* @return The icon.
**/
public Icon getIcon(int size, boolean open)
{
if (size != 32)
{
return icon16_;
}
return icon32_;
}
/**
* Returns the index of the specified child.
*
* @param child The child.
* @return The index of the specified child.
**/
public int getIndex(TreeNode child)
{
for (int index=0; index < groupCount_; index++)
{
if (children_[index] == child)
{
return index;
}
}
return -1;
}
/**
* Returns the parent node.
*
* @return The parent node, or null if there is no parent.
**/
public TreeNode getParent()
{
return parent_;
}
/**
* Returns the properties pane.
*
* @return The properties pane.
**/
public VPropertiesPane getPropertiesPane()
{
return null;
}
/**
* Returns a property value.
*
* @param propertyIdentifier The property identifier.
* The choices are
*
* - NAME_PROPERTY
*
- DESCRIPTION_PROPERTY
*
* @return The property value, or null if the
* property identifier is not recognized.
**/
public Object getPropertyValue(Object propertyIdentifier)
{
if (propertyIdentifier == NAME_PROPERTY)
{
return this;
}
if (propertyIdentifier == DESCRIPTION_PROPERTY)
{
return description_;
}
return null;
}
/**
* Returns the system in which the system
* values resides.
*
* @return The system in which the system
* values resides.
*
* @see com.ibm.as400.access.SystemValueList
**/
public AS400 getSystem()
{
return systemValueList_.getSystem();
}
/**
* Returns the system value list.
* @return The SystemValueList object.
**/
public SystemValueList getSystemValueList()
{
return systemValueList_;
}
/**
* Returns the text representation of the system value list.
*
* @return The text representation of the system value list.
**/
public String getText()
{
return description_;
}
/**
* Initializes the transient data.
**/
private void initializeTransient()
{
errorEventSupport_= new ErrorEventSupport(this);
objectEventSupport_= new VObjectEventSupport(this);
propertyChangeSupport_= new PropertyChangeSupport(this);
vetoableChangeSupport_= new VetoableChangeSupport(this);
workingEventSupport_= new WorkingEventSupport(this);
children_ = new VSystemValueGroup[groupCount_];
for (int i=0; i
© 2015 - 2025 Weber Informatics LLC | Privacy Policy