Class SpecializedAction
- java.lang.Object
- 
- ca.cgjennings.apps.arkham.project.TaskAction
- 
- ca.cgjennings.apps.arkham.project.SpecializedAction
 
 
- 
- All Implemented Interfaces:
- IconProvider
 
 public abstract class SpecializedAction extends TaskAction A superclass for actions that specialize one of the built-in actions by modifying their behaviour. The same action can be specialized multiple times. As long as each instance is well-behaved and passes all calls that they don't care about on tosuperAction, multiple specializations can only interfere with each other if there is overlap between the cases they specialize. When two or more actions specialize the same case (such as files with a certain extension), only the last one registered takes effect.- Author:
- Chris Jennings 
 
- 
- 
Field SummaryFields Modifier and Type Field Description protected TaskActionsuperAction
 - 
Constructor SummaryConstructors Constructor Description SpecializedAction()Creates a specialized action that is initially uninstalled.SpecializedAction(TaskAction action)Use this instance to specialize an already registered action.SpecializedAction(java.lang.String name)Use this instance to specialize an already registered action by name.
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description booleanappliesTo(Project project, Task task, Member member)Returnstrueif this action can be performed on the specified member of a project, project or a task.booleanappliesToSelection(Member[] members)Returnstrueif this action is applicable to any of the specifiedMembers.java.lang.StringgetActionName()Returns a unique internal name for this action.java.lang.StringgetLabel()Returns the human-readable name of this action.TaskActiongetRootAction()Returns the topmost super action in the chain of specialized actions.TaskActiongetSuperAction()Returns the action that this action specializes.voidinstall(TaskAction action)Installs this specialized action as a specialization of the specified action.voidinstall(java.lang.String name)Installs this specialized action as a specialized version of the action with the given name.booleanperform(Project project, Task task, Member member)Perform this action on a member of a project, a project or a task.booleanperformOnSelection(Member[] members)Applies this action to all of the specified project members.voiduninstall()Removes this action from the specialization chain of the root action.- 
Methods inherited from class ca.cgjennings.apps.arkham.project.TaskActionapplyToChildren, getDescription, getIcon, resolveTarget, toString
 
- 
 
- 
- 
- 
Field Detail- 
superActionprotected TaskAction superAction 
 
- 
 - 
Constructor Detail- 
SpecializedActionpublic SpecializedAction() Creates a specialized action that is initially uninstalled. Specialized actions must be installed onto an existing action. The result of trying to use this action before it is installed are undefined.
 - 
SpecializedActionpublic SpecializedAction(TaskAction action) Use this instance to specialize an already registered action.- Parameters:
- action- the action that this action specializes
- Throws:
- java.lang.IllegalArgumentException- if- actionis not registered
 
 - 
SpecializedActionpublic SpecializedAction(java.lang.String name) Use this instance to specialize an already registered action by name.- Parameters:
- name- the name of the action that this action specializes
- Throws:
- java.lang.IllegalArgumentException- if there is no action registered with the given name
 
 
- 
 - 
Method Detail- 
installpublic void install(java.lang.String name) Installs this specialized action as a specialized version of the action with the given name.- Parameters:
- name- the name of the action to specialize
- Throws:
- java.lang.IllegalArgumentException- if no task is registered with the given name
- See Also:
- install(ca.cgjennings.apps.arkham.project.TaskAction)
 
 - 
installpublic void install(TaskAction action) Installs this specialized action as a specialization of the specified action. Note that this action can only be installed once: to reinstall a specialized action after uninstallation, create a new instance of the specialized action.- Parameters:
- action- the action that this action is a more specialized version of
 
 - 
getActionNamepublic final java.lang.String getActionName() Returns a unique internal name for this action. Actions can be looked up by this name. The default implementation returns the class name, converted to lowercase.This implementation returns the same name as that of the original action. - Overrides:
- getActionNamein class- TaskAction
- Returns:
- the internal name of this action
 
 - 
getLabelpublic java.lang.String getLabel() Returns the human-readable name of this action.This implementation returns the result of calling this method on the original action. - Specified by:
- getLabelin class- TaskAction
- Returns:
- the name used to create menu items for this action, localized if possible
 
 - 
performOnSelectionpublic boolean performOnSelection(Member[] members) Applies this action to all of the specified project members. By overriding this, you can modify what happens when the user tries to initiate this action. For example, you could add a verification dialog and call the super implementation only if the user verifies the action.This implementation returns the result of calling this method on the original action. - Overrides:
- performOnSelectionin class- TaskAction
- Returns:
- trueif and only if the action is successfully applied to all of the members
 
 - 
performpublic boolean perform(Project project, Task task, Member member) Perform this action on a member of a project, a project or a task. If the project itself is the target,taskandmemberwill benull. If a task is the target, thenmemberwill be null. If an error occurs while executing the task, then it is the action's responsibility to inform the user. This method can returnfalseto indicate that if the action is being applied to multiple members, it should stop immediately rather than continue to the next member.This implementation returns the result of calling this method on the original action. - Specified by:
- performin class- TaskAction
- Parameters:
- project- the project that is being acted upon
- task- the task within the project that is being acted upon;- nullif acting on a project
- member- the specific member within the task to act upon;- nullif this is a project or task
 
 - 
appliesToSelectionpublic boolean appliesToSelection(Member[] members) Returnstrueif this action is applicable to any of the specifiedMembers. By overriding this, you can modify whether an action is listed depending on which other members are selected. For example, you could create a command that can only be applied to a singleton selection by checking the length ofmembersand returningfalseif it is not 1, and otherwise calling the super implementation.This implementation returns the result of calling this method on the original action. - Overrides:
- appliesToSelectionin class- TaskAction
- Parameters:
- members- a list of zero or more members
- Returns:
- trueis the action can be applied to at least one member
 
 - 
appliesTopublic boolean appliesTo(Project project, Task task, Member member) Returnstrueif this action can be performed on the specified member of a project, project or a task. If the project itself is the target,taskandmemberwill benull. If a task is the target, thenmemberwill be null. If an error occurs while executing the task, then it is the action's responsibility to inform the user. This method can returnfalseto indicate that if the action is being applied to multiple members, it should stop immediately rather than continue to the next member.This implementation returns the result of calling this method on the original action. - Specified by:
- appliesToin class- TaskAction
- Parameters:
- project- the project that is being acted upon
- task- the task within the project that is being acted upon;- nullif acting on a project
- member- the specific member within the task to act upon;- nullif this is a project or task
 
 - 
getSuperActionpublic final TaskAction getSuperAction() Returns the action that this action specializes.- Returns:
- the parent action that this action specialized
 
 - 
getRootActionpublic final TaskAction getRootAction() Returns the topmost super action in the chain of specialized actions. This is similar togetSuperAction(), except that if an action has been specialized multiple times, this method will return the original, unspecialized action at the top of the specialization chain.- Returns:
- the original, unspecialized action
 
 - 
uninstallpublic void uninstall() Removes this action from the specialization chain of the root action.
 
- 
 
-