ARTICLE

Coding Pattern for Enabling Controls

Posted by roger bruvold Articles | Design & Architecture July 16, 2008
Writing code to enable the controls in your application at the correct times can be difficult and error prone. This article describes a reliable way to code your control enabling.
Reader Level:
Download Files:
 

Introduction

When developing applications that have menus, toolbars, and other controls, the task of enabling the correct controls as the application changes state can be difficult. In this article, I will present a design pattern that will simplify coding and make it possible to verify the correctness of the enabling logic by inspecting the code.

The pattern I'm presenting works by putting all the enabling logic in one place and coding it in a way that makes the intent clear.  This means you shouldn't have to test and fix until it appears to work.

An example

The example is meant to be small, but have complex enough enabling conditions to make it interesting.  It's a simple list editor that saves the list contents in an XML file.

The enabling rules

Here are the enabling rules for the example:

  1. The Load button is only enabled when there is some text in the path text box.  Also, we don't want to load a new file without saving changes to the old one, so the Load button isn't enabled when there are changes that have not been saved.
  2. For demonstration, no more than five items can be in the list, so the Add button is enabled only when there are less than five items in the list.
  3. The Remove Item button is only enabled when an item is selected. 
  4. The Edit Selection button is only enabled when an item is selected. 
  5. The Save button is only enabled if a change has been made since the last save and there is some text in the path text box.
  6. The Up button is enabled when an item in the list box is selected that's not the top item.
  7. The Down button is enabled when an item in the list box is selected that's not the bottom item.

Steps

  1. Create an EnableControls method.
  2. Define and set Boolean variables that will become the primitives in our control enabling language.
  3. For each menu item, toolbar item, or other control, combine the Boolean "primitives", using ands (&&) and ors (||) to define the conditions under which each control is enabled.
  4. Call the EnableControls method from the event handler for each event that has the potential to change the application state.

private void EnableControls()

{

   // define primitives

   bool havePath = textBoxPath.Text != "";

   bool isSelection = listBoxItems.SelectedIndex != -1;

   bool canAdd = listBoxItems.Items.Count < _maxItemCount;

   bool canMoveUp = listBoxItems.SelectedIndex > 0;

   bool canMoveDown =

        listBoxItems.SelectedIndex < listBoxItems.Items.Count - 1;

 

   // use primitives to enable controls

   buttonAddItem.Enabled = canAdd;

   buttonRemoveItem.Enabled = isSelection;

   buttonLoad.Enabled = havePath && !_dirty;

   buttonEditSelection.Enabled = isSelection;

   buttonSave.Enabled = _documentIsLoaded && _dirty && havePath;

   buttonUp.Enabled = isSelection && canMoveUp;

   buttonDown.Enabled = isSelection && canMoveDown;

}

 

// call EnableControls from event handlers

private void listBoxNodes_SelectedIndexChanged(object sender,EventArgs)

{

   EnableControls();

}

As you read this code, the conditions that allow each control to be enabled are clear.  If you're like me, you will still make mistakes.  But the mistakes we be much easier to find and repair, and less likely to cause other errors.

Conclusion

Imagine what the code would look like if we had put enabling logic into each event, as is commonly done.  And this is a simple example.  Real-life applications can be much more complex, and the need to manage complexity through good programming patterns is even greater.

Login to add your contents and source code to this article
post comment
     
COMMENT USING
PREMIUM SPONSORS
Over-C is a holistic consortium of communications and technology specialists. We build, deploy and market both business as well as consumer products and solutions.
Join a Chapter
SPONSORED BY
  • PDF reports have never been easier to create. With our included WYSIWYG Designer, you can layout your reports, set up your data source and let DynamicPDF ReportWriter do the rest.
Join a Chapter