Package adams.flow.source
Class EnterValue
-
- 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 EnterValue extends AbstractInteractiveSource implements AutomatableInteractiveActor, RestorableActor, InteractionDisplayLocationSupporter
Pops up a dialog, prompting the user to enter a value.
Input/output:
- generates:
java.lang.String
-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: EnterValue
-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 <adams.core.base.BaseString> (property: message) The message to prompt the user with; variables get expanded prior to prompting user. default: Please enter a value
-initial-value <adams.core.base.BaseString> (property: initialValue) The initial value to prompt the user with; variables get expanded prior to prompting user. default:
-selection-values <adams.core.base.BaseString> [-selection-values ...] (property: selectionValues) The options to let the user choose from. default:
-num-cols <int> (property: numCols) The number of columns to use for the text box. default: 20 minimum: 1
-num-rows <int> (property: numRows) The number of rows to use for the text box. default: 1 minimum: 1
-use-buttons <boolean> (property: useButtons) If enabled and selection values are available, then instead of a dropdown list a button per selection value is displayed. default: false
-vertical-buttons <boolean> (property: verticalButtons) If enabled and buttons are used, they get displayed vertically rather than horizontally. default: false
-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}
- Author:
- fracpete (fracpete at waikato dot ac dot nz)
- See Also:
- Serialized Form
-
-
Field Summary
Fields Modifier and Type Field Description static String
KEY_INITIAL
protected GUIHelper.DialogCommunication
m_Comm
for communicating with the input dialog.protected InteractionDisplayLocation
m_DisplayLocation
where to display the prompt.protected BaseString
m_InitialValue
the initial value.protected BaseString
m_Message
the message for the user.protected boolean
m_NonInteractive
whether to automate the actor.protected int
m_NumCols
the number of columns for the text box.protected int
m_NumRows
the number of rows for the text box.protected Token
m_OutputToken
the output token to broadcast.protected boolean
m_RestorationEnabled
whether restoration is enabled.protected PlaceholderFile
m_RestorationFile
the file to store the restoration state in.protected BaseString[]
m_SelectionValues
options to select from.protected boolean
m_UseButtons
whether to use buttons instead of a dropdown list.protected boolean
m_VerticalButtons
whether to use vertical buttons instead of a horizontal ones.-
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 EnterValue()
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description void
defineOptions()
Adds options to the internal list of options.String
displayLocationTipText()
Returns the tip text for this property.String
doInteract()
Performs the interaction with the user.String
doInteractHeadless()
Performs the interaction with the user in a headless environment.Class[]
generates()
Returns the class of objects that it generates.InteractionDisplayLocation
getDisplayLocation()
Returns where the interaction is being displayed.BaseString
getInitialValue()
Returns the initial value the user is prompted with.BaseString
getMessage()
Returns the message the user is prompted with.int
getNumCols()
Returns the number of columns to use for the text box.int
getNumRows()
Returns the number of rows to use for the text box.String
getQuickInfo()
Returns a quick info about the actor, which will be displayed in the GUI.PlaceholderFile
getRestorationFile()
Returns the file for storing the state.BaseString[]
getSelectionValues()
Returns the selection values to prompt the user with.boolean
getUseButtons()
Returns whether to use buttons or a drop-down list for the selection values.boolean
getVerticalButtons()
Returns whether to use vertical buttons instead of horizontal ones.String
globalInfo()
Returns a string describing the object.boolean
hasPendingOutput()
Checks whether there is pending output to be collected after executing the flow item.String
initialValueTipText()
Returns the tip text for this property.boolean
isNonInteractive()
Returns whether interactiveness is enabled/disabled.boolean
isRestorationEnabled()
Returns whether restoration is enabled.String
messageTipText()
Returns the tip text for this property.String
nonInteractiveTipText()
Returns the tip text for this property.String
numColsTipText()
Returns the tip text for this property.String
numRowsTipText()
Returns the tip text for this property.Token
output()
Returns the generated token.protected void
reset()
Resets the scheme.String
restorationEnabledTipText()
Returns the tip text for this property.String
restorationFileTipText()
Returns the tip text for this property.String
selectionValuesTipText()
Returns the tip text for this property.void
setDisplayLocation(InteractionDisplayLocation value)
Sets where the interaction is being displayed.void
setInitialValue(BaseString value)
Sets the initial value to prompt the user with.void
setMessage(BaseString value)
Sets the message to prompt the user with.void
setNonInteractive(boolean value)
Sets whether to enable/disable interactiveness.void
setNumCols(int value)
Sets the number of columns to use for the text box.void
setNumRows(int value)
Sets the number of rows to use for the text box.void
setRestorationEnabled(boolean value)
Sets whether to enable restoration.void
setRestorationFile(PlaceholderFile value)
Sets the file for storing the state.void
setSelectionValues(BaseString[] value)
Sets the selection values to prompt the user with.void
setUseButtons(boolean value)
Sets whether to use buttons or a drop-down list for the selection values.void
setVerticalButtons(boolean value)
Sets whether to use vertical buttons instead of horizontal ones.void
stopExecution()
Stops the execution.boolean
supportsHeadlessInteraction()
Returns whether headless interaction is supported.String
useButtonsTipText()
Returns the tip text for this property.String
verticalButtonsTipText()
Returns the tip text for this property.-
Methods inherited from class adams.flow.source.AbstractInteractiveSource
customStopMessageTipText, deregisterWindow, doExecute, findCallableActor, getActualParentComponent, getCustomStopMessage, getParentComponentActor, getStopFlowIfCanceled, getStopMode, getUseOuterWindow, initialize, 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, setUp, setVariables, shallowCopy, shallowCopy, silentTipText, sizeOf, skipTipText, stopExecution, stopFlowOnErrorTipText, updateDetectedVariables, updatePrefix, updateVariables, variableChanged, wrapUp
-
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, setUp, setVariables, shallowCopy, shallowCopy, sizeOf, stopExecution, toCommandLine, variableChanged, wrapUp
-
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
-
KEY_INITIAL
public static final String KEY_INITIAL
- See Also:
- Constant Field Values
-
m_Message
protected BaseString m_Message
the message for the user.
-
m_InitialValue
protected BaseString m_InitialValue
the initial value.
-
m_SelectionValues
protected BaseString[] m_SelectionValues
options to select from.
-
m_NonInteractive
protected boolean m_NonInteractive
whether to automate the actor.
-
m_NumCols
protected int m_NumCols
the number of columns for the text box.
-
m_NumRows
protected int m_NumRows
the number of rows for the text box.
-
m_UseButtons
protected boolean m_UseButtons
whether to use buttons instead of a dropdown list.
-
m_VerticalButtons
protected boolean m_VerticalButtons
whether to use vertical buttons instead of a horizontal ones.
-
m_DisplayLocation
protected InteractionDisplayLocation m_DisplayLocation
where to display the prompt.
-
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_OutputToken
protected Token m_OutputToken
the output token to broadcast.
-
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:
globalInfo
in interfaceGlobalInfoSupporter
- Specified by:
globalInfo
in classAbstractOptionHandler
- Returns:
- a description suitable for displaying in the gui
-
defineOptions
public void defineOptions()
Adds options to the internal list of options.- Specified by:
defineOptions
in interfaceOptionHandler
- Overrides:
defineOptions
in classAbstractInteractiveSource
-
reset
protected void reset()
Resets the scheme.- Overrides:
reset
in classAbstractInteractiveSource
-
getQuickInfo
public String getQuickInfo()
Returns a quick info about the actor, which will be displayed in the GUI.- Specified by:
getQuickInfo
in interfaceActor
- Specified by:
getQuickInfo
in interfaceQuickInfoSupporter
- Overrides:
getQuickInfo
in classAbstractActor
- Returns:
- null if no info available, otherwise short string
-
setMessage
public void setMessage(BaseString value)
Sets the message to prompt the user with.- Parameters:
value
- the message
-
getMessage
public BaseString 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.
-
setInitialValue
public void setInitialValue(BaseString value)
Sets the initial value to prompt the user with.- Parameters:
value
- the initial value
-
getInitialValue
public BaseString getInitialValue()
Returns the initial value the user is prompted with.- Returns:
- the initial value
-
initialValueTipText
public String initialValueTipText()
Returns the tip text for this property.- Returns:
- tip text for this property suitable for displaying in the GUI or for listing the options.
-
setSelectionValues
public void setSelectionValues(BaseString[] value)
Sets the selection values to prompt the user with.- Parameters:
value
- the selection values
-
getSelectionValues
public BaseString[] getSelectionValues()
Returns the selection values to prompt the user with.- Returns:
- the selection values
-
selectionValuesTipText
public String selectionValuesTipText()
Returns the tip text for this property.- Returns:
- tip text for this property suitable for displaying in the GUI or for listing the options.
-
setNumCols
public void setNumCols(int value)
Sets the number of columns to use for the text box.- Parameters:
value
- the number of columns
-
getNumCols
public int getNumCols()
Returns the number of columns to use for the text box.- Returns:
- the number of columns
-
numColsTipText
public String numColsTipText()
Returns the tip text for this property.- Returns:
- tip text for this property suitable for displaying in the GUI or for listing the options.
-
setNumRows
public void setNumRows(int value)
Sets the number of rows to use for the text box.- Parameters:
value
- the number of rows
-
getNumRows
public int getNumRows()
Returns the number of rows to use for the text box.- Returns:
- the number of rows
-
numRowsTipText
public String numRowsTipText()
Returns the tip text for this property.- Returns:
- tip text for this property suitable for displaying in the GUI or for listing the options.
-
setUseButtons
public void setUseButtons(boolean value)
Sets whether to use buttons or a drop-down list for the selection values.- Parameters:
value
- true if to use buttons
-
getUseButtons
public boolean getUseButtons()
Returns whether to use buttons or a drop-down list for the selection values.- Returns:
- true if to use buttons
-
useButtonsTipText
public String useButtonsTipText()
Returns the tip text for this property.- Returns:
- tip text for this property suitable for displaying in the GUI or for listing the options.
-
setVerticalButtons
public void setVerticalButtons(boolean value)
Sets whether to use vertical buttons instead of horizontal ones.- Parameters:
value
- true if to use buttons
-
getVerticalButtons
public boolean getVerticalButtons()
Returns whether to use vertical buttons instead of horizontal ones.- Returns:
- true if to use buttons
-
verticalButtonsTipText
public String verticalButtonsTipText()
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:
setDisplayLocation
in interfaceInteractionDisplayLocationSupporter
- Parameters:
value
- the location
-
getDisplayLocation
public InteractionDisplayLocation getDisplayLocation()
Returns where the interaction is being displayed.- Specified by:
getDisplayLocation
in interfaceInteractionDisplayLocationSupporter
- Returns:
- the location
-
displayLocationTipText
public String displayLocationTipText()
Returns the tip text for this property.- Specified by:
displayLocationTipText
in 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:
setNonInteractive
in interfaceAutomatableInteraction
- Specified by:
setNonInteractive
in interfaceAutomatableInteractiveActor
- Parameters:
value
- if true actor is not interactive, but automated
-
isNonInteractive
public boolean isNonInteractive()
Returns whether interactiveness is enabled/disabled.- Specified by:
isNonInteractive
in interfaceAutomatableInteraction
- Specified by:
isNonInteractive
in interfaceAutomatableInteractiveActor
- Returns:
- true if actor is not interactive i.e., automated
-
nonInteractiveTipText
public String nonInteractiveTipText()
Returns the tip text for this property.- Specified by:
nonInteractiveTipText
in interfaceAutomatableInteraction
- Specified by:
nonInteractiveTipText
in 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:
setRestorationEnabled
in interfaceRestorableActor
- Parameters:
value
- true if to enable restoration
-
isRestorationEnabled
public boolean isRestorationEnabled()
Returns whether restoration is enabled.- Specified by:
isRestorationEnabled
in interfaceRestorableActor
- Returns:
- true if restoration enabled
-
restorationEnabledTipText
public String restorationEnabledTipText()
Returns the tip text for this property.- Specified by:
restorationEnabledTipText
in 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:
setRestorationFile
in interfaceRestorableActor
- Parameters:
value
- the file
-
getRestorationFile
public PlaceholderFile getRestorationFile()
Returns the file for storing the state.- Specified by:
getRestorationFile
in interfaceRestorableActor
- Returns:
- the file
-
restorationFileTipText
public String restorationFileTipText()
Returns the tip text for this property.- Specified by:
restorationFileTipText
in interfaceRestorableActor
- 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:
generates
in interfaceOutputProducer
- Returns:
- java.lang.String.class
-
doInteract
public String doInteract()
Performs the interaction with the user.- Specified by:
doInteract
in interfaceInteractiveActor
- Specified by:
doInteract
in classAbstractInteractiveSource
- Returns:
- null if successfully interacted, otherwise error message
-
supportsHeadlessInteraction
public boolean supportsHeadlessInteraction()
Returns whether headless interaction is supported.- Specified by:
supportsHeadlessInteraction
in interfaceInteractiveActor
- Overrides:
supportsHeadlessInteraction
in 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:
doInteractHeadless
in interfaceInteractiveActor
- Overrides:
doInteractHeadless
in classAbstractInteractiveSource
- Returns:
- null if successfully interacted, otherwise error message
-
output
public Token output()
Returns the generated token.- Specified by:
output
in 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:
hasPendingOutput
in interfaceOutputProducer
- Returns:
- true if there is pending output
-
stopExecution
public void stopExecution()
Stops the execution. No message set.- Specified by:
stopExecution
in interfaceActor
- Specified by:
stopExecution
in interfaceStoppable
- Overrides:
stopExecution
in classAbstractActor
-
-