summaryrefslogtreecommitdiff
path: root/src/gui
diff options
context:
space:
mode:
authorGraeme Geldenhuys <graeme@mastermaths.co.za>2011-09-21 12:46:24 +0200
committerGraeme Geldenhuys <graeme@mastermaths.co.za>2011-09-21 12:46:24 +0200
commit64fd64e8b6ab19515eea9fa64c56dde92d29f014 (patch)
treeb2b67941dd88a9e9a12c0ef9b871aee823e0969f /src/gui
parentf91ce56a1e21a20be8fb00b797ccaebfe3755dc9 (diff)
downloadfpGUI-64fd64e8b6ab19515eea9fa64c56dde92d29f014.tar.xz
fixed bug where combobox hint closes the dropdown window.
Diffstat (limited to 'src/gui')
-rw-r--r--src/gui/fpg_combobox.pas25
1 files changed, 22 insertions, 3 deletions
diff --git a/src/gui/fpg_combobox.pas b/src/gui/fpg_combobox.pas
index 6f482f72..8c10f195 100644
--- a/src/gui/fpg_combobox.pas
+++ b/src/gui/fpg_combobox.pas
@@ -87,6 +87,9 @@ type
FFocusItem: integer;
FItems: TStringList;
FBtnPressed: Boolean;
+ FStoredShowHint: Boolean;
+ procedure DisableShowHint;
+ procedure RestoreShowHint;
procedure SetMargin(const AValue: integer); virtual;
procedure SetAutoSize(const AValue: Boolean); virtual;
procedure CalculateInternalButtonRect; virtual;
@@ -186,6 +189,7 @@ implementation
uses
fpg_listbox,
+ dbugintf,
math;
@@ -268,6 +272,18 @@ begin
Repaint;
end;
+procedure TfpgBaseComboBox.DisableShowHint;
+begin
+ FStoredShowHint := ShowHint;
+ ShowHint := False;
+ fpgApplication.HideHint; // make sure Application hint timer doesn't fire
+end;
+
+procedure TfpgBaseComboBox.RestoreShowHint;
+begin
+ ShowHint := FStoredShowHint;
+end;
+
procedure TfpgBaseComboBox.SetMargin(const AValue: integer);
begin
if (FMargin = AValue) or (AValue <= 0) then
@@ -302,6 +318,7 @@ end;
procedure TfpgBaseComboBox.InternalOnClose(Sender: TObject);
begin
DoOnCloseUp;
+ RestoreShowHint;
end;
procedure TfpgBaseComboBox.InternalItemsChanged(Sender: TObject);
@@ -448,6 +465,7 @@ begin
FBtnPressed := False;
FOnChange := nil;
FExtraHint := '';
+ FStoredShowHint := ShowHint;
end;
destructor TfpgBaseComboBox.Destroy;
@@ -556,14 +574,15 @@ var
r: TfpgRect;
begin
{$IFDEF DEBUG}
- write('DoDropDown');
+ SendMethodEnter('TfpgBaseStaticCombo.DoDropDown');
{$ENDIF}
if (not Assigned(FDropDown)) or (not FDropDown.HasHandle) then
begin
{$IFDEF DEBUG}
- writeln('.... creating');
+ SendDebug('.... creating');
{$ENDIF}
FreeAndNil(FDropDown);
+ DisableShowHint; // disable hints while dropdown is visible
FDropDown := TComboboxDropdownWindow.Create(nil, self);
ddw := TComboboxDropdownWindow(FDropDown);
@@ -590,7 +609,7 @@ begin
else
begin
{$IFDEF DEBUG}
- writeln('.... destroying');
+ SendDebug('.... destroying');
{$ENDIF}
FBtnPressed := False;
ddw := TComboboxDropdownWindow(FDropDown);