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

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

There is a newer version: 20.0.8
Show newest version
///////////////////////////////////////////////////////////////////////////////
//                                                                             
// JTOpen (IBM Toolbox for Java - OSS version)                              
//                                                                             
// Filename: VOutput.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.AS400Calendar;
import com.ibm.as400.access.SpooledFile;
import com.ibm.as400.access.PrintObject;
import com.ibm.as400.access.QSYSObjectPathName;
import javax.swing.Icon;
import java.util.Calendar;

/**
The VOutput class defines the representation of a
spooled file output on a system for use in various
models and panes in this package.

Most errors are reported as ErrorEvents rather than throwing exceptions. Users should listen for ErrorEvents in order to diagnose and recover from error conditions.

VOutput objects generate the following events:

  • ErrorEvent
  • VObjectEvent
  • WorkingEvent
@see com.ibm.as400.access.SpooledFile @deprecated Use Java Swing instead, along with the classes in package com.ibm.as400.access **/ public class VOutput implements VObject { private static final String copyright = "Copyright (C) 1997-2000 International Business Machines Corporation and others."; /** Property identifier for the output name. **/ public static final Object OUTPUTNAME_PROPERTY = "Output name"; /** Property identifier for the user specified data. **/ public static final Object USERSPECDATA_PROPERTY = "User-specified data"; /** Property identifier for the name of the user of the job which produced the output. **/ public static final Object USER_PROPERTY = "User"; /** Property identifier for the status of the output. **/ public static final Object STATUS_PROPERTY = "Status"; /** Property identifier for the printer name. **/ public static final Object PRINTER_PROPERTY = "Printer"; /** Property identifier for the number of pages per copy. **/ public static final Object PAGESPERCOPY_PROPERTY = "Pages per copy"; /** Property identifier for the number of copies left. **/ public static final Object COPIESLEFT_PROPERTY = "Copies left"; /** Property identifier for the date the output was created. **/ public static final Object DATE_PROPERTY = "Date created"; /** Property identifier for the form type. **/ public static final Object FORMTYPE_PROPERTY = "Form type"; /** Property identifier for the name of the job which produced the output. **/ public static final Object JOB_PROPERTY = "Job"; /** Property identifier for the number of the job which produced the output. **/ public static final Object JOBNUMBER_PROPERTY = "Job number"; /** Property identifier for the number of the output. **/ public static final Object NUMBER_PROPERTY = "Number"; /** Property identifier for the output queue. **/ public static final Object OUTPUTQUEUE_PROPERTY = "Output queue"; /** Property identifier for the output queue library. **/ public static final Object OUTPUTQUEUELIB_PROPERTY = "Output queue library"; /** Property identifier for the priority of the output on the output queue. **/ public static final Object PRIORITY_PROPERTY = "Priority on output queue"; /** Property identifier for the user comment. **/ public static final Object USERCOMMENT_PROPERTY = "User comment"; // Static data. private static final String description_ = ResourceLoader.getPrintText ("OUTPUT_DESCRIPTION"); private static final Icon icon16_ = ResourceLoader.getIcon ("VOutput16.gif", description_); private static final Icon icon32_ = ResourceLoader.getIcon ("VOutput32.gif", description_); private static final String closedText_ = ResourceLoader.getPrintText ("CLOSED"); private static final String heldText_ = ResourceLoader.getPrintText ("HELD"); private static final String msgWaitingText_ = ResourceLoader.getPrintText ("MESSAGE_WAITING"); private static final String openText_ = ResourceLoader.getPrintText ("OPEN"); private static final String pendingText_ = ResourceLoader.getPrintText ("PENDING"); private static final String printerText_ = ResourceLoader.getPrintText ("PRINTER"); private static final String readyText_ = ResourceLoader.getPrintText ("READY"); private static final String savedText_ = ResourceLoader.getPrintText ("SAVED"); private static final String writingText_ = ResourceLoader.getPrintText ("WRITING"); private static final String standardText_ = ResourceLoader.getPrintText ("STANDARD"); private static final String jobValueText_ = ResourceLoader.getPrintText ("JOB_VALUE"); private static final String notAssignedText_ = ResourceLoader.getPrintText ("NOT_ASSIGNED"); private static final String groupText_ = ResourceLoader.getPrintText ("GROUP"); private static Calendar calendar_ = AS400Calendar.getGregorianInstance (); // private data. private VAction[] actions_ = null; private Integer actionsLock_ = new Integer (0); private SpooledFile splF_ = null; private VPrinterOutput parent_ = null; private VPropertiesPane propertiesPane_ = null; private Integer propertiesPaneLock_ = new Integer (0); private Integer reloadLock_ = new Integer (0); // event support private ErrorEventSupport errorEventSupport_ = new ErrorEventSupport (this); private VObjectEventSupport objectEventSupport_ = new VObjectEventSupport (this); private WorkingEventSupport workingEventSupport_ = new WorkingEventSupport (this); /** Constructs a VOutput object. @param parent The parent. @param spooledFile The spooled file. **/ public VOutput (VPrinterOutput parent, SpooledFile spooledFile) { if (spooledFile == null) throw new NullPointerException ("spooledFile"); if (parent == null) throw new NullPointerException ("parent"); parent_ = parent; splF_ = spooledFile; // create the actions actions_ = new VAction[8]; /* @A1C - changed from 7 to 8 */ actions_[0] = new OutputReplyAction (this, spooledFile); // reply actions_[1] = new OutputHoldAction (this, spooledFile); // hold actions_[2] = new OutputReleaseAction (this, spooledFile); // release actions_[3] = new OutputPrintNextAction (this, spooledFile, parent); // print next actions_[4] = new OutputSendAction (this, spooledFile); // send actions_[5] = new OutputMoveAction (this, spooledFile, parent);// move actions_[6] = new OutputDeleteAction (this, spooledFile, parent);// delete actions_[7] = new OutputViewAction (this, spooledFile); // view @A1A // Listen to the actions for (int i = 0; i< actions_.length; ++i) { actions_[i].addErrorListener (errorEventSupport_); actions_[i].addVObjectListener (objectEventSupport_); actions_[i].addWorkingListener (workingEventSupport_); } // end for // create the properties pane and listen for the events propertiesPane_ = new OutputPropertiesPane (this, spooledFile); propertiesPane_.addErrorListener (errorEventSupport_); propertiesPane_.addVObjectListener (objectEventSupport_); propertiesPane_.addWorkingListener (workingEventSupport_); } /** 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 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 list of actions that can be performed.
  • reply
  • hold
  • release
  • print next
  • send
  • move
  • delete
  • view
@return The actions. **/ public synchronized VAction[] getActions () { // need to enable/disable the correct ones try { // retrieve the spooled file status String status = splF_.getStringAttribute(PrintObject.ATTR_SPLFSTATUS).trim(); // reply action valid when status is message waiting if (status.equals("*MESSAGE")) actions_[0].setEnabled(true); else actions_[0].setEnabled(false); // hold action valid only when status is released if (status.equals("*READY")) actions_[1].setEnabled(true); else actions_[1].setEnabled(false); // release action valid only when status is held if (status.equals("*HELD")) actions_[2].setEnabled(true); else actions_[2].setEnabled(false); } // end try block catch (Exception e) { errorEventSupport_.fireError (e); } // end catch block return actions_; } /** Returns the default action. @return Always null. There is no default action. **/ public VAction getDefaultAction () { return null; } /** Returns the icon. @param size The icon size, either 16 or 32. If any other value is given, then return the default of 16. @param open This parameter has no effect. @return The icon. **/ public Icon getIcon (int size, boolean open) { if (size == 32) return icon32_; else return icon16_; } /** Returns the properties pane. @return The properties pane. **/ public VPropertiesPane getPropertiesPane () { return propertiesPane_; } /** Returns a property value. @param propertyIdentifier The property identifier. The choices are
  • NAME_PROPERTY
  • DESCRIPTION_PROPERTY
  • OUTPUTNAME_PROPERTY
  • USERSPECDATA_PROPERTY
  • USER_PROPERTY
  • STATUS_PROPERTY
  • PRINTER_PROPERTY
  • PAGESPERCOPY_PROPERTY
  • COPIESLEFT_PROPERTY
  • DATE_PROPERTY
  • FORMTYPE_PROPERTY
  • JOB_PROPERTY
  • JOBNUMBER_PROPERTY
  • NUMBER_PROPERTY
  • OUTPUTQUEUE_PROPERTY
  • OUTPUTQUEUELIB_PROPERTY
  • PRIORITY_PROPERTY
  • USERCOMMENT_PROPERTY
@return The property value, or null if the property identifier is not recognized. **/ public synchronized Object getPropertyValue (Object propertyIdentifier) { try { // Get the file name. if (propertyIdentifier == NAME_PROPERTY) return this; // Get the description. else if (propertyIdentifier == DESCRIPTION_PROPERTY) return description_; // Output name if (propertyIdentifier == OUTPUTNAME_PROPERTY) return this; // user-specified data else if (propertyIdentifier == USERSPECDATA_PROPERTY) return splF_.getStringAttribute(PrintObject.ATTR_USERDATA); // user else if (propertyIdentifier == USER_PROPERTY) return splF_.getJobUser(); // status else if (propertyIdentifier == STATUS_PROPERTY) { String status = splF_.getStringAttribute(PrintObject.ATTR_SPLFSTATUS); if (status.trim().equals("*CLOSED")) return closedText_; if (status.trim().equals("*HELD")) return heldText_; if (status.trim().equals("*MESSAGE")) return msgWaitingText_; if (status.trim().equals("*OPEN")) return openText_; if (status.trim().equals("*PENDING")) return pendingText_; if (status.trim().equals("*PRINTER")) return printerText_; if (status.trim().equals("*READY")) return readyText_; if (status.trim().equals("*SAVED")) return savedText_; if (status.trim().equals("*WRITING")) return writingText_; return null; } // printer else if (propertyIdentifier == PRINTER_PROPERTY) { String ptrAssigned = splF_.getStringAttribute(PrintObject.ATTR_PRTASSIGNED).trim(); if (ptrAssigned.equals("1")) // splf is assigned to a printer return splF_.getStringAttribute(PrintObject.ATTR_PRINTER); else if (ptrAssigned.equals("2")) // splf is assigned to multiple printers return groupText_; else // splf is not assigned return notAssignedText_; } // pages per copy else if (propertyIdentifier == PAGESPERCOPY_PROPERTY) return splF_.getIntegerAttribute(PrintObject.ATTR_PAGES); // copies left else if (propertyIdentifier == COPIESLEFT_PROPERTY) return splF_.getIntegerAttribute(PrintObject.ATTR_COPIESLEFT); // date else if (propertyIdentifier == DATE_PROPERTY) { // return the string that represents the date String date = splF_.getStringAttribute(PrintObject.ATTR_DATE); String time = splF_.getStringAttribute(PrintObject.ATTR_TIME); // @A2A - The code below used to substring (1,3) for the year, omitting // the century field, and did not add 1900 to the result (base time). // The code now substrings (0,3) and adds in 1900, thus // producing the correct date. calendar_.set((Integer.parseInt(date.substring(0,3)) + 1900),// year @A2C Integer.parseInt(date.substring(3,5))-1,// month is zero based Integer.parseInt(date.substring(5,7)), // day Integer.parseInt(time.substring(0,2)), // hour Integer.parseInt(time.substring(2,4)), // minute Integer.parseInt(time.substring(4,6))); // second return calendar_.getTime(); } // formtype else if (propertyIdentifier == FORMTYPE_PROPERTY) { // we need to check for *STD String formType = splF_.getStringAttribute(PrintObject.ATTR_FORMTYPE).trim(); if (formType.equals("*STD")) return standardText_; else return formType; } // job else if (propertyIdentifier == JOB_PROPERTY) return splF_.getJobName(); // job number else if (propertyIdentifier == JOBNUMBER_PROPERTY) return splF_.getJobNumber(); // spooled file number else if (propertyIdentifier == NUMBER_PROPERTY) return new Integer(splF_.getNumber()); // output queue else if (propertyIdentifier == OUTPUTQUEUE_PROPERTY) { // extract the IFS path name of the output queue QSYSObjectPathName outQPath = new QSYSObjectPathName(splF_.getStringAttribute(PrintObject.ATTR_OUTPUT_QUEUE)); // send back just the output queue name return outQPath.getObjectName(); } // output queue library else if (propertyIdentifier == OUTPUTQUEUELIB_PROPERTY) { // extract the IFS path name of the output queue QSYSObjectPathName outQPath = new QSYSObjectPathName(splF_.getStringAttribute(PrintObject.ATTR_OUTPUT_QUEUE)); // send back just the output queue library return outQPath.getLibraryName(); } // priority else if (propertyIdentifier == PRIORITY_PROPERTY) { // we need to check for *JOB String outQPty = splF_.getStringAttribute(PrintObject.ATTR_OUTPTY).trim(); if (outQPty.equals("*JOB")) return jobValueText_; else return outQPty; } // user comment else if (propertyIdentifier == USERCOMMENT_PROPERTY) return splF_.getStringAttribute(PrintObject.ATTR_USERCMT); // By default, return null. return null; } // end try block catch (Exception e) { errorEventSupport_.fireError (e); } // end catch block // By default, return null. return null; } // @A3A /** Returns the spooled file. @return The spooled file. **/ public SpooledFile getSpooledFile() { return splF_; } /** Loads information about the object from the system. **/ public synchronized void load () { workingEventSupport_.fireStartWorking(); try { // just update the spooled file attributes splF_.update(); } // end try block catch (Exception e) { errorEventSupport_.fireError (e); } // end catch block workingEventSupport_.fireStopWorking (); } /** Returns the text. This is the name of the spooled file (output). @return The text, which is the name of the spooled file. **/ public String getText () { // return the name of the spooled file return splF_.getName(); } /** Removes an error listener. @param listener The listener. **/ public void removeErrorListener (ErrorListener listener) { errorEventSupport_.removeErrorListener (listener); } /** Removes a VObjectListener. @param listener The listener. **/ public void removeVObjectListener (VObjectListener listener) { objectEventSupport_.removeVObjectListener (listener); } /** Removes a working listener. @param listener The listener. **/ public void removeWorkingListener (WorkingListener listener) { workingEventSupport_.removeWorkingListener (listener); } /** Returns the string representation. This is the spooled file (output) name, number, job user, job number and job name, all separated with blanks. @return The string representation. **/ public String toString () { return splF_.getName().trim() + " " + Integer.toString(splF_.getNumber()) + " " + splF_.getJobUser().trim() + " " + splF_.getJobNumber().trim() + " " + splF_.getJobName().trim(); } } // end VOutput class




© 2015 - 2025 Weber Informatics LLC | Privacy Policy