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

src.com.ibm.as400.vaccess.ProgramCallMenuItem Maven / Gradle / Ivy

There is a newer version: 20.0.8
Show newest version
///////////////////////////////////////////////////////////////////////////////
//                                                                             
// JTOpen (IBM Toolbox for Java - OSS version)                              
//                                                                             
// Filename: ProgramCallMenuItem.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.ProgramCall;
import com.ibm.as400.access.ProgramParameter;
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 ProgramCallMenuItem class represents a menu item
that calls a program when pressed.
The results of the program are returned in a message list.

ProgramCallMenuItem objects generate the following events:

  • ActionCompletedEvent
  • ErrorEvent
  • PropertyChangeEvent
@see com.ibm.as400.access.ProgramCall @see com.ibm.as400.access.AS400Message @deprecated Use Java Swing instead, along with the classes in package com.ibm.as400.access **/ public class ProgramCallMenuItem extends JMenuItem implements Serializable { private static final String copyright = "Copyright (C) 1997-2000 International Business Machines Corporation and others."; // Properties. ProgramCall program_ = null; // Private. // Event support. transient ActionCompletedEventSupport actionCompletedEventSupport_; // Private. transient ErrorEventSupport errorEventSupport_; // Private. transient private PropertyChangeSupport propertyChangeSupport_; transient private VetoableChangeSupport vetoableChangeSupport_; /** Constructs a ProgramCallMenuItem object. **/ public ProgramCallMenuItem() { program_ = new ProgramCall (); initializeTransient (); } /** Constructs a ProgramCallMenuItem object. @param text The menu item text, or null if there is no text. **/ public ProgramCallMenuItem(String text) { super(text); program_ = new ProgramCall (); initializeTransient (); } /** Constructs a ProgramCallMenuItem 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 ProgramCallMenuItem(String text, Icon icon) { super(text,icon); program_ = new ProgramCall (); initializeTransient (); } /** Constructs a ProgramCallMenuItem 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 the programs are run. **/ public ProgramCallMenuItem(String text, Icon icon, AS400 system) { super(text, icon); program_ = new ProgramCall (system); initializeTransient (); } /** Constructs a ProgramCallMenuItem 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 the programs are run. @param program The program name as a fully qualified path name in the library file system. The library and program name must each be 10 characters or less. @param parmlist A list of up to 35 parameters with which to run the program. **/ public ProgramCallMenuItem(String text, Icon icon, AS400 system, String program, ProgramParameter[] parmlist) { super(text, icon); program_ = new ProgramCall (system, program, parmlist); initializeTransient (); } /** Adds a listener to be notified when an action is completed. @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 parameter to the parameter list. @param parameter The parameter. @exception PropertyVetoException If the change is vetoed. **/ public void addParameter (ProgramParameter parameter) throws PropertyVetoException { program_.addParameter (parameter); } /** 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 message list resulting from the last program call that was run. @return The message list. **/ public AS400Message[] getMessageList() { return program_.getMessageList(); } /** Returns the message text from the last program that was run. The message will be the first message received. @return The message text. **/ public String getMessageText() { AS400Message[] msglist = program_.getMessageList(); if (msglist.length==0) return ""; else return msglist[0].getText(); } /** Returns the parameter list. @return The parameter list. **/ public ProgramParameter[] getParameterList() { return program_.getParameterList(); } /** Returns the program which will be called when the button is pressed. @return The program which will be called when the button is pressed. **/ public String getProgram() { return program_.getProgram(); } /** Returns the system on which programs are run. @return The system on which programs are run. **/ public AS400 getSystem() { return program_.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); program_.addActionCompletedListener (actionCompletedEventSupport_); program_.addPropertyChangeListener (propertyChangeSupport_); program_.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 list of parameters to pass to the program. @param parmlist A list of up to 35 parameters with which to run the program. It will replace any parameters previously set. @exception PropertyVetoException If the change is vetoed. **/ public void setParameterList(ProgramParameter[] parmlist) throws PropertyVetoException { program_.setParameterList (parmlist); } /** Sets the program. @param program The program. @exception PropertyVetoException If the change is vetoed. **/ public void setProgram (String program) throws PropertyVetoException { program_.setProgram (program); } /** Sets the system on which programs are run. @param system The system on which programs are run. @exception PropertyVetoException If the change is vetoed. **/ public void setSystem(AS400 system) throws PropertyVetoException { program_.setSystem( system ); } private class ActionListener_ implements ActionListener { public void actionPerformed (ActionEvent event) { // Set the cursor to a wait cursor. WorkingCursorAdapter cursorAdapter = new WorkingCursorAdapter (ProgramCallMenuItem.this); cursorAdapter.startWorking (new WorkingEvent (this)); // Run the command. try { program_.run(); } catch (Exception e) { errorEventSupport_.fireError (e); } // Set the cursor back. cursorAdapter.stopWorking (new WorkingEvent (this)); } } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy