Package adams.flow.source
Class EnterManyValues
-
- All Implemented Interfaces:
AdditionalInformationHandler,CleanUpHandler,Destroyable,GlobalInfoSupporter,LoggingLevelHandler,LoggingSupporter,OptionHandler,QuickInfoSupporter,ShallowCopySupporter<Actor>,SizeOfHandler,Stoppable,StoppableWithFeedback,VariablesInspectionHandler,VariableChangeListener,Actor,AutomatableInteraction,AutomatableInteractiveActor,ErrorHandler,InteractionDisplayLocationSupporter,InteractiveActor,InteractiveActorWithCustomParentComponent,OutputProducer,RestorableActor,StopModeSupporter,Serializable,Comparable
public class EnterManyValues extends AbstractInteractiveSource implements AutomatableInteractiveActor, RestorableActor, InteractionDisplayLocationSupporter
Pops up a dialog, prompting the user to enter one or more values.
Input/output:
- generates:
adams.data.spreadsheet.SpreadSheet
-logging-level <OFF|SEVERE|WARNING|INFO|CONFIG|FINE|FINER|FINEST> (property: loggingLevel) The logging level for outputting errors and debugging output. default: WARNING min-user-mode: Expert
-name <java.lang.String> (property: name) The name of the actor. default: EnterManyValues
-annotation <adams.core.base.BaseAnnotation> (property: annotations) The annotations to attach to this actor. default:
-skip <boolean> (property: skip) If set to true, transformation is skipped and the input token is just forwarded as it is. default: false
-stop-flow-on-error <boolean> (property: stopFlowOnError) If set to true, the flow execution at this level gets stopped in case this actor encounters an error; the error gets propagated; useful for critical actors. default: false min-user-mode: Expert
-silent <boolean> (property: silent) If enabled, then no errors are output in the console; Note: the enclosing actor handler must have this enabled as well. default: false min-user-mode: Expert
-stop-if-canceled <boolean> (property: stopFlowIfCanceled) If enabled, the flow gets stopped in case the user cancels the dialog. default: false
-custom-stop-message <java.lang.String> (property: customStopMessage) The custom stop message to use in case a user cancelation stops the flow (default is the full name of the actor) default:
-stop-mode <GLOBAL|STOP_RESTRICTOR> (property: stopMode) The stop mode to use. default: GLOBAL
-parent-component-actor <adams.flow.core.CallableActorReference> (property: parentComponentActor) The (optional) callable actor to use as parent component instead of the flow panel. default: unknown min-user-mode: Expert
-use-outer-window <boolean> (property: useOuterWindow) If enabled, the outer window (dialog/frame) is used instead of the component of the callable actor. default: false min-user-mode: Expert
-message <java.lang.String> (property: message) The message to prompt the user with; variables get automatically expanded. default: Please enter values
-value <adams.flow.source.valuedefinition.AbstractValueDefinition> [-value ...] (property: values) The value definitions that define the dialog prompting the user to enter the values. default:
-output-type <SPREADSHEET|KEY_VALUE_PAIRS|KEY_VALUE_PAIRS_ARRAY|MAP> (property: outputType) How to output the entered data. default: SPREADSHEET
-display-location <DIALOG|NOTIFICATION_AREA> (property: displayLocation) Determines where the interaction is being displayed. default: DIALOG
-non-interactive <boolean> (property: nonInteractive) If enabled, the initial value is forwarded without user interaction. default: false
-restoration-enabled <boolean> (property: restorationEnabled) If enabled, the state of the actor is being preserved and attempted to read in again next time this actor is executed. default: false
-restoration-file <adams.core.io.PlaceholderFile> (property: restorationFile) The file to store the restoration information in. default: ${CWD}-width <int> (property: width) The width for the dialog, -1 for default. default: -1 minimum: -1
- Author:
- fracpete (fracpete at waikato dot ac dot nz)
- See Also:
- Serialized Form
-
-
Nested Class Summary
Nested Classes Modifier and Type Class Description static classEnterManyValues.OutputTypeDefines how to output the data that the user entered.
-
Field Summary
Fields Modifier and Type Field Description protected GUIHelper.DialogCommunicationm_Commfor communicating with the input dialog.protected InteractionDisplayLocationm_DisplayLocationwhere to display the prompt.protected Stringm_Messagethe message for the user.protected booleanm_NonInteractivewhether to automate the actor.protected EnterManyValues.OutputTypem_OutputTypehow to output the data.protected Listm_Queuethe list of tokens to output.protected booleanm_RestorationEnabledwhether restoration is enabled.protected PlaceholderFilem_RestorationFilethe file to store the restoration state in.protected AbstractValueDefinition[]m_Valuesthe value definitions.protected intm_Widththe width of the dialog.-
Fields inherited from class adams.flow.source.AbstractInteractiveSource
m_CallableActor, m_CustomStopMessage, m_Helper, m_ParentComponentActor, m_ParentComponentActorConfigured, m_StopFlowIfCanceled, m_StopMode, m_UseOuterWindow
-
Fields inherited from class adams.flow.core.AbstractActor
m_Annotations, m_BackupState, m_DetectedObjectVariables, m_DetectedVariables, m_ErrorHandler, m_Executed, m_Executing, m_ExecutionListeningSupporter, m_FullName, m_LoggingPrefix, m_Name, m_Parent, m_ScopeHandler, m_Self, m_Silent, m_Skip, m_StopFlowOnError, m_StopMessage, m_Stopped, m_StorageHandler, m_VariablesUpdated
-
Fields inherited from class adams.core.option.AbstractOptionHandler
m_OptionManager
-
Fields inherited from class adams.core.logging.LoggingObject
m_Logger, m_LoggingIsEnabled, m_LoggingLevel
-
Fields inherited from interface adams.flow.core.Actor
FILE_EXTENSION, FILE_EXTENSION_GZ
-
Fields inherited from interface adams.flow.core.InteractiveActor
INTERACTION_CANCELED
-
-
Constructor Summary
Constructors Constructor Description EnterManyValues()
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description voidaddValue(AbstractValueDefinition value)Adds a single value definition at the end.voiddefineOptions()Adds options to the internal list of options.StringdisplayLocationTipText()Returns the tip text for this property.StringdoInteract()Performs the interaction with the user.StringdoInteractHeadless()Performs the interaction with the user in a headless environment.protected StringdoInteractInDialog(PropertiesParameterPanel panel, JPanel panelMsg)Performs the interaction using a dialog.protected StringdoInteractInNotificationArea(PropertiesParameterPanel panel, JPanel panelMsg)Performs the interaction using the notification area.Class[]generates()Returns the class of objects that it generates.protected PropertiesgetDefaultProperties()Returns the default properties.InteractionDisplayLocationgetDisplayLocation()Returns where the interaction is being displayed.StringgetMessage()Returns the message the user is prompted with.EnterManyValues.OutputTypegetOutputType()Returns how to output the entered data.StringgetQuickInfo()Returns a quick info about the actor, which will be displayed in the GUI.PlaceholderFilegetRestorationFile()Returns the file for storing the state.AbstractValueDefinition[]getValues()Returns the value definitions.intgetWidth()Returns the width for the dialog.StringglobalInfo()Returns a string describing the object.booleanhasPendingOutput()Checks whether there is pending output to be collected after executing the flow item.protected voidinitialize()Initializes the members.booleanisNonInteractive()Returns whether interactiveness is enabled/disabled.booleanisRestorationEnabled()Returns whether restoration is enabled.StringmessageTipText()Returns the tip text for this property.StringnonInteractiveTipText()Returns the tip text for this property.Tokenoutput()Returns the generated token.StringoutputTypeTipText()Returns the tip text for this property.protected Token[]propertiesToOutputType(Properties props)Converts the properties into the requested output type.protected SpreadSheetpropertiesToSpreadSheet(Properties props)Converts the properties into a spreadsheet (single row, with property names for column names).protected voidreset()Resets the scheme.StringrestorationEnabledTipText()Returns the tip text for this property.StringrestorationFileTipText()Returns the tip text for this property.voidsetDisplayLocation(InteractionDisplayLocation value)Sets where the interaction is being displayed.voidsetMessage(String value)Sets the message to prompt the user with.voidsetNonInteractive(boolean value)Sets whether to enable/disable interactiveness.voidsetOutputType(EnterManyValues.OutputType value)Sets how to output the entered data.voidsetRestorationEnabled(boolean value)Sets whether to enable restoration.voidsetRestorationFile(PlaceholderFile value)Sets the file for storing the state.StringsetUp()Initializes the item for flow execution.voidsetValues(AbstractValueDefinition[] value)Sets the value definitions.voidsetWidth(int value)Sets the width for the dialog.voidstopExecution()Stops the execution.booleansupportsHeadlessInteraction()Returns whether headless interaction is supported.StringvaluesTipText()Returns the tip text for this property.StringwidthTipText()Returns the tip text for this property.voidwrapUp()Cleans up after the execution has finished.-
Methods inherited from class adams.flow.source.AbstractInteractiveSource
customStopMessageTipText, deregisterWindow, doExecute, findCallableActor, getActualParentComponent, getCustomStopMessage, getParentComponentActor, getStopFlowIfCanceled, getStopMode, getUseOuterWindow, parentComponentActorTipText, registerWindow, setCustomStopMessage, setParentComponentActor, setStopFlowIfCanceled, setStopMode, setUseOuterWindow, stopFlowIfCanceledTipText, stopModeTipText, useOuterWindowTipText
-
Methods inherited from class adams.flow.core.AbstractActor
annotationsTipText, backupState, canInspectOptions, canPerformSetUpCheck, cleanUp, compareTo, configureLogger, destroy, equals, execute, finalUpdateVariables, findVariables, findVariables, forceVariables, forCommandLine, forName, forName, getAdditionalInformation, getAnnotations, getDefaultName, getDetectedVariables, getErrorHandler, getFlowActors, getFlowExecutionListeningSupporter, getFullName, getName, getNextSibling, getParent, getParentComponent, getPreviousSibling, getRoot, getScopeHandler, getSilent, getSkip, getStopFlowOnError, getStopMessage, getStorageHandler, getVariables, handleError, handleException, hasErrorHandler, hasStopMessage, index, isBackedUp, isExecuted, isExecuting, isFinished, isHeadless, isStopped, nameTipText, performSetUpChecks, performVariableChecks, postExecute, preExecute, pruneBackup, pruneBackup, restoreState, setAnnotations, setErrorHandler, setName, setParent, setSilent, setSkip, setStopFlowOnError, setVariables, shallowCopy, shallowCopy, silentTipText, sizeOf, skipTipText, stopExecution, stopFlowOnErrorTipText, updateDetectedVariables, updatePrefix, updateVariables, variableChanged
-
Methods inherited from class adams.core.option.AbstractOptionHandler
cleanUpOptions, finishInit, getDefaultLoggingLevel, getOptionManager, loggingLevelTipText, newOptionManager, setLoggingLevel, toCommandLine, toString
-
Methods inherited from class adams.core.logging.LoggingObject
getLogger, getLoggingLevel, initializeLogging, isLoggingEnabled
-
Methods inherited from class java.lang.Object
clone, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
-
Methods inherited from interface adams.flow.core.Actor
cleanUp, compareTo, destroy, equals, execute, findVariables, getAnnotations, getDefaultName, getDetectedVariables, getErrorHandler, getFlowExecutionListeningSupporter, getFullName, getName, getNextSibling, getParent, getParentComponent, getPreviousSibling, getRoot, getScopeHandler, getSilent, getSkip, getStopFlowOnError, getStopMessage, getStorageHandler, getVariables, handleError, hasErrorHandler, hasStopMessage, index, isExecuted, isFinished, isHeadless, isStopped, setAnnotations, setErrorHandler, setName, setParent, setSilent, setSkip, setStopFlowOnError, setVariables, shallowCopy, shallowCopy, sizeOf, stopExecution, toCommandLine, variableChanged
-
Methods inherited from interface adams.core.AdditionalInformationHandler
getAdditionalInformation
-
Methods inherited from interface adams.flow.core.InteractiveActor
customStopMessageTipText, getCustomStopMessage, getStopFlowIfCanceled, setCustomStopMessage, setStopFlowIfCanceled, stopFlowIfCanceledTipText
-
Methods inherited from interface adams.core.logging.LoggingLevelHandler
getLoggingLevel, setLoggingLevel
-
Methods inherited from interface adams.core.logging.LoggingSupporter
getLogger, isLoggingEnabled
-
Methods inherited from interface adams.core.option.OptionHandler
cleanUpOptions, getOptionManager
-
Methods inherited from interface adams.flow.core.StopModeSupporter
getStopMode, setStopMode, stopModeTipText
-
Methods inherited from interface adams.core.VariablesInspectionHandler
canInspectOptions
-
-
-
-
Field Detail
-
m_Message
protected String m_Message
the message for the user.
-
m_Values
protected AbstractValueDefinition[] m_Values
the value definitions.
-
m_OutputType
protected EnterManyValues.OutputType m_OutputType
how to output the data.
-
m_NonInteractive
protected boolean m_NonInteractive
whether to automate the actor.
-
m_RestorationEnabled
protected boolean m_RestorationEnabled
whether restoration is enabled.
-
m_RestorationFile
protected PlaceholderFile m_RestorationFile
the file to store the restoration state in.
-
m_Width
protected int m_Width
the width of the dialog.
-
m_DisplayLocation
protected InteractionDisplayLocation m_DisplayLocation
where to display the prompt.
-
m_Queue
protected List m_Queue
the list of tokens to output.
-
m_Comm
protected GUIHelper.DialogCommunication m_Comm
for communicating with the input dialog.
-
-
Method Detail
-
globalInfo
public String globalInfo()
Returns a string describing the object.- Specified by:
globalInfoin interfaceGlobalInfoSupporter- Specified by:
globalInfoin classAbstractOptionHandler- Returns:
- a description suitable for displaying in the gui
-
defineOptions
public void defineOptions()
Adds options to the internal list of options.- Specified by:
defineOptionsin interfaceOptionHandler- Overrides:
defineOptionsin classAbstractInteractiveSource
-
initialize
protected void initialize()
Initializes the members.- Overrides:
initializein classAbstractInteractiveSource
-
reset
protected void reset()
Resets the scheme.- Overrides:
resetin classAbstractInteractiveSource
-
getQuickInfo
public String getQuickInfo()
Returns a quick info about the actor, which will be displayed in the GUI.- Specified by:
getQuickInfoin interfaceActor- Specified by:
getQuickInfoin interfaceQuickInfoSupporter- Overrides:
getQuickInfoin classAbstractActor- Returns:
- null if no info available, otherwise short string
-
setMessage
public void setMessage(String value)
Sets the message to prompt the user with.- Parameters:
value- the message
-
getMessage
public String getMessage()
Returns the message the user is prompted with.- Returns:
- the message
-
messageTipText
public String messageTipText()
Returns the tip text for this property.- Returns:
- tip text for this property suitable for displaying in the GUI or for listing the options.
-
addValue
public void addValue(AbstractValueDefinition value)
Adds a single value definition at the end.- Parameters:
value- the definition to add
-
setValues
public void setValues(AbstractValueDefinition[] value)
Sets the value definitions.- Parameters:
value- the definitions
-
getValues
public AbstractValueDefinition[] getValues()
Returns the value definitions.- Returns:
- the definitions
-
valuesTipText
public String valuesTipText()
Returns the tip text for this property.- Returns:
- tip text for this property suitable for displaying in the GUI or for listing the options.
-
setOutputType
public void setOutputType(EnterManyValues.OutputType value)
Sets how to output the entered data.- Parameters:
value- the type
-
getOutputType
public EnterManyValues.OutputType getOutputType()
Returns how to output the entered data.- Returns:
- the type
-
outputTypeTipText
public String outputTypeTipText()
Returns the tip text for this property.- Returns:
- tip text for this property suitable for displaying in the GUI or for listing the options.
-
setDisplayLocation
public void setDisplayLocation(InteractionDisplayLocation value)
Sets where the interaction is being displayed.- Specified by:
setDisplayLocationin interfaceInteractionDisplayLocationSupporter- Parameters:
value- the location
-
getDisplayLocation
public InteractionDisplayLocation getDisplayLocation()
Returns where the interaction is being displayed.- Specified by:
getDisplayLocationin interfaceInteractionDisplayLocationSupporter- Returns:
- the location
-
displayLocationTipText
public String displayLocationTipText()
Returns the tip text for this property.- Specified by:
displayLocationTipTextin interfaceInteractionDisplayLocationSupporter- Returns:
- tip text for this property suitable for displaying in the GUI or for listing the options.
-
setNonInteractive
public void setNonInteractive(boolean value)
Sets whether to enable/disable interactiveness.- Specified by:
setNonInteractivein interfaceAutomatableInteraction- Specified by:
setNonInteractivein interfaceAutomatableInteractiveActor- Parameters:
value- if true actor is not interactive, but automated
-
isNonInteractive
public boolean isNonInteractive()
Returns whether interactiveness is enabled/disabled.- Specified by:
isNonInteractivein interfaceAutomatableInteraction- Specified by:
isNonInteractivein interfaceAutomatableInteractiveActor- Returns:
- true if actor is not interactive i.e., automated
-
nonInteractiveTipText
public String nonInteractiveTipText()
Returns the tip text for this property.- Specified by:
nonInteractiveTipTextin interfaceAutomatableInteraction- Specified by:
nonInteractiveTipTextin interfaceAutomatableInteractiveActor- Returns:
- tip text for this property suitable for displaying in the GUI or for listing the options.
-
setRestorationEnabled
public void setRestorationEnabled(boolean value)
Sets whether to enable restoration.- Specified by:
setRestorationEnabledin interfaceRestorableActor- Parameters:
value- true if to enable restoration
-
isRestorationEnabled
public boolean isRestorationEnabled()
Returns whether restoration is enabled.- Specified by:
isRestorationEnabledin interfaceRestorableActor- Returns:
- true if restoration enabled
-
restorationEnabledTipText
public String restorationEnabledTipText()
Returns the tip text for this property.- Specified by:
restorationEnabledTipTextin interfaceRestorableActor- Returns:
- tip text for this property suitable for displaying in the GUI or for listing the options.
-
setRestorationFile
public void setRestorationFile(PlaceholderFile value)
Sets the file for storing the state.- Specified by:
setRestorationFilein interfaceRestorableActor- Parameters:
value- the file
-
getRestorationFile
public PlaceholderFile getRestorationFile()
Returns the file for storing the state.- Specified by:
getRestorationFilein interfaceRestorableActor- Returns:
- the file
-
restorationFileTipText
public String restorationFileTipText()
Returns the tip text for this property.- Specified by:
restorationFileTipTextin interfaceRestorableActor- Returns:
- tip text for this property suitable for displaying in the GUI or for listing the options.
-
setWidth
public void setWidth(int value)
Sets the width for the dialog.- Parameters:
value- the width
-
getWidth
public int getWidth()
Returns the width for the dialog.- Returns:
- the width
-
widthTipText
public String widthTipText()
Returns the tip text for this property.- Returns:
- tip text for this property suitable for displaying in the GUI or for listing the options.
-
generates
public Class[] generates()
Returns the class of objects that it generates.- Specified by:
generatesin interfaceOutputProducer- Returns:
- the classes
-
setUp
public String setUp()
Initializes the item for flow execution.- Specified by:
setUpin interfaceActor- Overrides:
setUpin classAbstractActor- Returns:
- null if everything is fine, otherwise error message
- See Also:
AbstractActor.reset()
-
getDefaultProperties
protected Properties getDefaultProperties()
Returns the default properties.- Returns:
- the default properties
-
propertiesToSpreadSheet
protected SpreadSheet propertiesToSpreadSheet(Properties props)
Converts the properties into a spreadsheet (single row, with property names for column names).- Parameters:
props- the properties to convert- Returns:
- the generated spreadsheet in a token
-
propertiesToOutputType
protected Token[] propertiesToOutputType(Properties props)
Converts the properties into the requested output type.- Parameters:
props- the properties to convert- Returns:
- the generated output type
-
doInteractInDialog
protected String doInteractInDialog(PropertiesParameterPanel panel, JPanel panelMsg)
Performs the interaction using a dialog.- Parameters:
panel- the panel with the parameterspanelMsg- the panel with the message for the user- Returns:
- null if successfully interacted, otherwise error message
-
doInteractInNotificationArea
protected String doInteractInNotificationArea(PropertiesParameterPanel panel, JPanel panelMsg)
Performs the interaction using the notification area.- Parameters:
panel- the panel with the parameterspanelMsg- the panel with the message for the user- Returns:
- null if successfully interacted, otherwise error message
-
doInteract
public String doInteract()
Performs the interaction with the user.- Specified by:
doInteractin interfaceInteractiveActor- Specified by:
doInteractin classAbstractInteractiveSource- Returns:
- null if successfully interacted, otherwise error message
-
supportsHeadlessInteraction
public boolean supportsHeadlessInteraction()
Returns whether headless interaction is supported.- Specified by:
supportsHeadlessInteractionin interfaceInteractiveActor- Overrides:
supportsHeadlessInteractionin classAbstractInteractiveSource- Returns:
- true if interaction in headless environment is possible
-
doInteractHeadless
public String doInteractHeadless()
Performs the interaction with the user in a headless environment.- Specified by:
doInteractHeadlessin interfaceInteractiveActor- Overrides:
doInteractHeadlessin classAbstractInteractiveSource- Returns:
- null if successfully interacted, otherwise error message
-
output
public Token output()
Returns the generated token.- Specified by:
outputin interfaceOutputProducer- Returns:
- the generated token
-
hasPendingOutput
public boolean hasPendingOutput()
Checks whether there is pending output to be collected after executing the flow item.- Specified by:
hasPendingOutputin interfaceOutputProducer- Returns:
- true if there is pending output
-
stopExecution
public void stopExecution()
Stops the execution. No message set.- Specified by:
stopExecutionin interfaceActor- Specified by:
stopExecutionin interfaceStoppable- Overrides:
stopExecutionin classAbstractActor
-
wrapUp
public void wrapUp()
Cleans up after the execution has finished.- Specified by:
wrapUpin interfaceActor- Overrides:
wrapUpin classAbstractActor
-
-