prevent lstBox item at index =0 ever to be selected

There is a list box with some items in it. Upon user click, the item value is printed on the screen.

Question: How can I make item at index 0 not to be selected ever?

What event I should be using. What code I should be using to perform as described below:

1. If the selected index is -1 and user selects item 0, nothing happens.
2. If the selected index is 3, for example, and user selects item 0, item 3 still remains selected preferably without postback.
LVL 34
Mike EghtebasDatabase and Application DeveloperAsked:
Who is Participating?
I wear a lot of hats...

"The solutions and answers provided on Experts Exchange have been extremely helpful to me over the last few years. I wear a lot of hats - Developer, Database Administrator, Help Desk, etc., so I know a lot of things but not a lot about one thing. Experts Exchange gives me answers from people who do know a lot about one thing, in a easy to use platform." -Todd S.

vr6rCommented:
Could do something like this...

On item at listbox index 0 do the following.
1. set the following properties to False:
    IsTabStop
    IsHitTestVisible

IsHitTestVisible prevents mouse selection by preventing hit test results for the element's rendered content.
IsTabStop prevents navigating to the element by tabbing to the control or up-arrowing when the listbox has focus.

2. Handle event "SelectionChanged" on the parent listbox control and set SelectedIndex = -1 if selectedIndex = 0.

This prevents cases where the user starts typing the text of the listbox item when the listbox control has focus.  By default the listbox will autoselect the item that matches the text the user is typing.

Here is the xaml and code behind for reference:

XAML
<ListBox x:Name="mylist" HorizontalAlignment="Left" Width="Auto" SelectionChanged="mylist_SelectionChanged">
    <ListBoxItem IsTabStop="False" IsHitTestVisible="False">option 0</ListBoxItem>
    <ListBoxItem>option 1</ListBoxItem>
    <ListBoxItem>option 2</ListBoxItem>
    <ListBoxItem>option 3</ListBoxItem>
    <ListBoxItem>option 4</ListBoxItem>
</ListBox>

Open in new window


Code
private void mylist_SelectionChanged(object sender, SelectionChangedEventArgs e)
{
    if (mylist.SelectedIndex == 0)
        mylist.SelectedIndex = -1;
}

Open in new window

0
Mike EghtebasDatabase and Application DeveloperAuthor Commented:
vr6r,

Sorry for the delay. The list boxes are generated on the fly:
  Dictionary<string, bool> listBoxes =   new Dictionary<string, bool>();
        listBoxes.Add("First_Name", false);
        listBoxes.Add("Last_Name", true);
        listBoxes.Add("Address", true);
        listBoxes.Add("City", true);
.
.
   private void AddListBoxes(Dictionary<string, bool> listBoxes)
    {
        Panel1.Controls.Clear();

        foreach (string box in (from listBox in listBoxes where listBox.Value select listBox.Key))
        {
              
            ListBox lb = new ListBox() { ID = "lst" + box };

            colCount += 1;
            if (colCount == colInRow + 1)
            {
                left = 50;
                top = 60 + height +50;
            }

            lb.Style["POSITION"] = "absolute";
            lb.Style["LEFT"] = left + "px";
            lb.Style["TOP"] = top + "px";
            lb.AutoPostBack=true;
            lb.DataTextField = box;
            lb.Style["Width"] = width + "px";
            lb.Style["Height"] = height + "px";
            lb.TextChanged +=new EventHandler(ListBoxSelectedIndexChanged);
            left += gap + width;
            left_old = left;
            Panel1.Controls.Add(lb);
            LoadListBoxes(lb);
        }
    }

Open in new window

I am using your code like this:
  private void ListBoxSelectedIndexChanged(object sender, EventArgs e)
    {
        if (mylist.SelectedIndex == 0)
        {
              mylist.SelectedIndex = -1;
        }
         else
         {
            // some other code to be added later
         }
    }

Open in new window


I have never used XAML. This will be new and exiting to learn how to apply it.

Question 1: Shall I just add an xml file and save it as XAML.xml to hold your code? How this is done?

Question 2: I possibly could include (by guesswork) how to include IsTabStop and IsHitTestVisible properties in AddListBoxes() method; but if possible at all please add them to AddListBoxes() starting on line 8, first box in this post.

Thank you,

Mike
0
Mike EghtebasDatabase and Application DeveloperAuthor Commented:
Hi vr6r,

I stumbled to something I want to run by you. Say we have the following items in our list box:

Jack    when I a "-" in front of Jack, upon click on this item the ChangeIndex event doesn't fire
Robert
Mike

Like:

-Jack    
Robert
Mike

This basically solves the problem. I wonder if you could take a look at it. I want to know how reliable is this.

Mike
0
vr6rCommented:
Honestly I have never tryied adding a dash in front of a list item to disable it so I couldn't say how reliable it is.

As far as xaml goes, you would generally use it by starting with a WPF c# project.  The xaml defines the UI of your app and you put your c# in the .cs code behind.  A quick google search will tell you much more than I would be able to - but generally speaking it is very flexibe & customizable.  Any desktop app I work on these days is WPF if I can help it at all.

So if you want to try tackling wpf then you can implement that sample as I posted previously.
0

Experts Exchange Solution brought to you by

Your issues matter to us.

Facing a tech roadblock? Get the help and guidance you need from experienced professionals who care. Ask your question anytime, anywhere, with no hassle.

Start your 7-day free trial
It's more than this solution.Get answers and train to solve all your tech problems - anytime, anywhere.Try it for free Edge Out The Competitionfor your dream job with proven skills and certifications.Get started today Stand Outas the employee with proven skills.Start learning today for free Move Your Career Forwardwith certification training in the latest technologies.Start your trial today
C#

From novice to tech pro — start learning today.