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

com.ibm.as400.vaccess.VSystemValueList Maven / Gradle / Ivy

There is a newer version: 20.0.8
Show newest version
///////////////////////////////////////////////////////////////////////////////
//                                                                             
// 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