Improve company productivity with a Business Account.Sign Up

x
  • Status: Solved
  • Priority: Medium
  • Security: Public
  • Views: 279
  • Last Modified:

Vb help

Please can you help me alter the code on my workbook.

Basically I would like for the listbox to display the up/down arrows when the userform is opened. So was Textbox1 to equal blank, then the arrows would display along with the listed range.

The picture describes what I would like to achieve but currently I would have to input "A" to achieve this.

Also something weird happens if I type "A" into textbox1 and then press the down arrow on my keyboard and then down again, for some reason it jumps to "Akrotiri" as opposed to descending down the range i.e. "Albania"

Many thanks for your help!

Gary



 help gary-test4.xls
0
Gazza83
Asked:
Gazza83
  • 4
  • 4
1 Solution
 
RobSampsonCommented:
Hi, see how this goes.  I've made the full list populate when the text box is empty.

The reason the list box was changing is because when an item is selected, it also updates the text box for the selected value, resulting in it being cleared.

I have prevented that, but I don't know how it's going to go with identifying the selection now.

Regards,

Rob.
gary-test4.xls
0
 
TinTombStoneCommented:
Should now start with the listbox loaded
Copy-of-gary-test4.xls
0
 
Gazza83Author Commented:
Thanks Rob, works well only now the mouse click selection function is disabled.

I was wondering if on selection, the listbox could remain on the value that was last selected.

Something like the attached? help
0
Free Tool: Site Down Detector

Helpful to verify reports of your own downtime, or to double check a downed website you are trying to access.

One of a set of tools we are providing to everyone as a way of saying thank you for being a part of the community.

 
Gazza83Author Commented:
Thanks Tom, I've tried the attached and it works on start up. The only thing is if I hit the down arrow on my keyboard twice, it jumps to Akrotiri as oppposed to moving through the 'drop down'
0
 
RobSampsonCommented:
OK, test this out.  It could be right.  I have removed the TextBox1_Change event, copying the code to a FillListBox sub.  This way, whenever the text box changes due to the list box being selected, it doesn't re-populate the list box.  As for the keystrokes, I've called FillListBox on the KeyUp event of the TextBox, instead of the Change event.

Regards,

Rob.
gary-test4.xls
0
 
Gazza83Author Commented:
Hi Rob, the code on the file you uploaded works brilliantly, just how I want it. The one problem is that Textbox4 doesn't seem to work:-

the old code had something like:-

End If
    Set rng1 = Sheets("DataSheet").Range("D1:D300").Find(TextBox1.Value, , xlValues, xlWhole)
    If Not rng1 Is Nothing Then TextBox4.Value = rng1.Offset(0, 1)
0
 
RobSampsonCommented:
Ah, change this:
Private Sub ListBox1_Change()
    On Error Resume Next
    If ListBox1.ListIndex > -1 Then
        TextBox1.Text = ListBox1.Value
    End If
    On Error GoTo 0
End Sub


to this
Private Sub ListBox1_Change()
    On Error Resume Next
    If ListBox1.ListIndex > -1 Then
        TextBox1.Text = ListBox1.Value
        CheckIfComplete
    End If
    On Error GoTo 0
End Sub


Regards,

Rob.
0
 
Gazza83Author Commented:
Many thanks for your help!
0
 
RobSampsonCommented:
No problem. Thanks for the grade.

Regards,

Rob.
0
Question has a verified solution.

Are you are experiencing a similar issue? Get a personalized answer when you ask a related question.

Have a better answer? Share it in a comment.

Join & Write a Comment

Featured Post

Free Tool: Site Down Detector

Helpful to verify reports of your own downtime, or to double check a downed website you are trying to access.

One of a set of tools we are providing to everyone as a way of saying thank you for being a part of the community.

  • 4
  • 4
Tackle projects and never again get stuck behind a technical roadblock.
Join Now