com.ibm.as400.vaccess.CommandCallMenuItem 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: CommandCallMenuItem.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.AS400Message;
import com.ibm.as400.access.ActionCompletedListener;
import com.ibm.as400.access.ActionCompletedEvent;
import com.ibm.as400.access.CommandCall;
import javax.swing.Icon;
import javax.swing.JMenuItem;
import java.awt.event.ActionListener;
import java.awt.event.ActionEvent;
import java.beans.PropertyChangeListener;
import java.beans.VetoableChangeListener;
import java.beans.PropertyVetoException;
import java.io.IOException;
import java.io.ObjectInputStream;
import java.io.Serializable;
/**
The CommandCallMenuItem class represents a menu item
that calls a CL command when selected.
Results of the command are returned in a message list.
CommandCallMenuItem objects generate the following events:
- ActionCompletedEvent
- ErrorEvent
- PropertyChangeEvent
@see com.ibm.as400.access.CommandCall
@see com.ibm.as400.access.AS400Message
@deprecated Use Java Swing instead, along with the classes in package com.ibm.as400.access
**/
public class CommandCallMenuItem
extends JMenuItem
implements Serializable
{
private static final String copyright = "Copyright (C) 1997-2000 International Business Machines Corporation and others.";
// Properties.
CommandCall command_ = null; // Private.
// Event support.
transient ActionCompletedEventSupport actionCompletedEventSupport_; // Private.
transient ErrorEventSupport errorEventSupport_; // Private.
transient private PropertyChangeSupport propertyChangeSupport_;
transient private VetoableChangeSupport vetoableChangeSupport_;
/**
Constructs a CommandCallMenuItem object.
**/
public CommandCallMenuItem()
{
command_ = new CommandCall ();
initializeTransient ();
}
/**
Constructs a CommandCallMenuItem object.
@param text The menu item text, or null if there is no text.
**/
public CommandCallMenuItem(String text)
{
super(text);
command_ = new CommandCall ();
initializeTransient ();
}
/**
Constructs a CommandCallMenuItem object.
@param text The menu item text, or null if there is no text.
@param icon The menu item icon, or null if there is no icon.
**/
public CommandCallMenuItem(String text, Icon icon)
{
super(text,icon);
command_ = new CommandCall ();
initializeTransient ();
}
/**
Constructs a CommandCallMenuItem object.
@param text The menu item text, or null if there is no text.
@param icon The menu item icon, or null if there is no icon.
@param system The system on which commands are run.
**/
public CommandCallMenuItem(String text,
Icon icon,
AS400 system)
{
super(text, icon);
command_ = new CommandCall (system);
initializeTransient ();
}
/**
Constructs a CommandCallMenuItem object.
@param text The menu item text, or null if there is no text.
@param icon The menu item icon, or null if there is no icon.
@param system The system on which commands are run.
@param command The command.
**/
public CommandCallMenuItem(String text,
Icon icon,
AS400 system,
String command)
{
super(text, icon);
command_ = new CommandCall (system, command);
initializeTransient ();
}
/**
Adds a listener to be notified when a command has been run on the system.
@param listener The listener.
**/
public void addActionCompletedListener(ActionCompletedListener listener)
{
actionCompletedEventSupport_.addActionCompletedListener (listener);
}
/**
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)
{
super.addPropertyChangeListener(listener); // @C1A
if (propertyChangeSupport_ != null) // @C1A
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);
}
/**
Returns the command.
@return The command.
**/
public String getCommand()
{
return command_.getCommand();
}
/**
Returns the message list resulting from the last command
that was run.
@return The message list.
**/
public AS400Message[] getMessageList()
{
return command_.getMessageList();
}
/**
Returns the text from the first message resulting from the
last command that was run.
@return The message text.
**/
public String getMessageText()
{
AS400Message[] msglist = command_.getMessageList();
if (msglist.length==0)
return "";
else
return msglist[0].getText();
}
/**
Returns the system on which commands are run.
@return The system on which commands are run.
**/
public AS400 getSystem()
{
return command_.getSystem();
}
/**
Initializes the transient data.
**/
private void initializeTransient ()
{
// Initialize the event support.
actionCompletedEventSupport_ = new ActionCompletedEventSupport (this);
errorEventSupport_ = new ErrorEventSupport (this);
propertyChangeSupport_ = new PropertyChangeSupport (this);
vetoableChangeSupport_ = new VetoableChangeSupport (this);
command_.addActionCompletedListener (actionCompletedEventSupport_);
command_.addPropertyChangeListener (propertyChangeSupport_);
command_.addVetoableChangeListener (vetoableChangeSupport_);
addActionListener (new ActionListener_ ());
}
/**
Restores the state of the object from an input stream.
This is used when deserializing an object.
@param in The input stream.
**/
private void readObject (ObjectInputStream in)
throws IOException, ClassNotFoundException
{
in.defaultReadObject ();
initializeTransient ();
}
/**
Removes a action completed listener.
@param listener The listener.
**/
public void removeActionCompletedListener (ActionCompletedListener listener)
{
actionCompletedEventSupport_.removeActionCompletedListener (listener);
}
/**
Removes an error listener.
@param listener The listener.
**/
public void removeErrorListener (ErrorListener listener)
{
errorEventSupport_.removeErrorListener (listener);
}
/**
Removes a property change listener.
@param listener The listener.
**/
public void removePropertyChangeListener (PropertyChangeListener listener)
{
propertyChangeSupport_.removePropertyChangeListener (listener);
}
/**
Removes a vetoable change listener.
@param listener The listener.
**/
public void removeVetoableChangeListener(VetoableChangeListener listener)
{
vetoableChangeSupport_.removeVetoableChangeListener (listener);
}
/**
Sets the command that is run when the button is pressed.
@param command The command that is run when the button is pressed.
@exception PropertyVetoException If the change is vetoed.
**/
public void setCommand(String command)
throws PropertyVetoException
{
command_.setCommand( command );
}
/**
Sets the system on which commands are run.
@param system The system on which commands are run.
@exception PropertyVetoException If the change is vetoed.
**/
public void setSystem(AS400 system)
throws PropertyVetoException
{
command_.setSystem( system );
}
private class ActionListener_
implements ActionListener
{
public void actionPerformed (ActionEvent event)
{
// Set the cursor to a wait cursor.
WorkingCursorAdapter cursorAdapter = new WorkingCursorAdapter (CommandCallMenuItem.this);
cursorAdapter.startWorking (new WorkingEvent (this));
// Run the command.
try {
command_.run();
}
catch (Exception e) {
errorEventSupport_.fireError (e);
}
// Set the cursor back.
cursorAdapter.stopWorking (new WorkingEvent (this));
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy