mirror of
				https://gitlab.com/freepascal.org/lazarus/lazarus.git
				synced 2025-10-25 00:33:14 +02:00 
			
		
		
		
	IDE: add a FilterEdit to IdeOptions dialog. Filters by all captions in option pages
git-svn-id: trunk@35665 -
This commit is contained in:
		
							parent
							
								
									62083c3eba
								
							
						
					
					
						commit
						19105dd155
					
				| @ -159,18 +159,18 @@ procedure TTreeFilterBranch.SortAndFilter; | ||||
| // Copy data from fOriginalData to fSortedData in sorted order | ||||
| var | ||||
|   Origi, i: Integer; | ||||
|   FileN: string; | ||||
|   s: string; | ||||
| begin | ||||
|   fSortedData.Clear; | ||||
|   for Origi:=0 to fOriginalData.Count-1 do begin | ||||
|     FileN:=fOriginalData[Origi]; | ||||
|     if (fOwner.Filter='') or (Pos(fOwner.Filter,lowercase(FileN))>0) then begin | ||||
|     s:=fOriginalData[Origi]; | ||||
|     if (fOwner.Filter='') or (Pos(fOwner.Filter,lowercase(s))>0) then begin | ||||
|       i:=fSortedData.Count-1; | ||||
|       while i>=0 do begin | ||||
|         if CompareFNs(FileN,fSortedData[i])>=0 then break; | ||||
|         if CompareFNs(s,fSortedData[i])>=0 then break; | ||||
|         dec(i); | ||||
|       end; | ||||
|       fSortedData.InsertObject(i+1,FileN, fOriginalData.Objects[Origi]); | ||||
|       fSortedData.InsertObject(i+1,s, fOriginalData.Objects[Origi]); | ||||
|     end; | ||||
|   end; | ||||
| end; | ||||
| @ -374,13 +374,23 @@ end; | ||||
| function TTreeFilterEdit.FilterTree(Node: TTreeNode): Boolean; | ||||
| // Filter all tree branches recursively, setting Node.Visible as needed. | ||||
| // Returns True if Node or its siblings or child nodes have visible items. | ||||
| var | ||||
|   ChildVisible: Boolean; | ||||
|   Pass, Done: Boolean; | ||||
| begin | ||||
|   Result:=False; | ||||
|   Done:=False; | ||||
|   while Node<>nil do | ||||
|   begin | ||||
|     // Call OnFilterItem handler. | ||||
|     Pass:=False; | ||||
|     if Assigned(OnFilterItem) then | ||||
|       Pass:=OnFilterItem(TObject(Node.Data), Done); | ||||
|     // Filter by item's title text if needed. | ||||
|     if not (Pass or Done) then | ||||
|       Pass:=(Filter='') or (Pos(Filter,lowercase(Node.Text))>0); | ||||
|     // Recursive call for child nodes. | ||||
|     Node.Visible:=FilterTree(Node.GetFirstChild) | ||||
|                   or (Filter='') or (Pos(Filter,lowercase(Node.Text))>0); | ||||
|     Node.Visible:=FilterTree(Node.GetFirstChild) or Pass; | ||||
|     if Node.Visible then | ||||
|       Result:=True; | ||||
|     Node:=Node.GetNextSibling; | ||||
| @ -409,7 +419,7 @@ begin | ||||
|     for i:=0 to fBranches.Count-1 do | ||||
|       fBranches[i].SortAndFilter; | ||||
|   end | ||||
|   else begin                             // Filter the whole tree. | ||||
|   else begin                  // Filter the whole tree (done in ApplyFilterCore). | ||||
|     // | ||||
|   end; | ||||
| end; | ||||
|  | ||||
| @ -1,8 +1,9 @@ | ||||
| object IDEOptionsDialog: TIDEOptionsDialog | ||||
|   Left = 317 | ||||
| inherited IDEOptionsDialog: TIDEOptionsDialog | ||||
|   Left = 318 | ||||
|   Height = 500 | ||||
|   Top = 304 | ||||
|   Top = 182 | ||||
|   Width = 700 | ||||
|   ActiveControl = CatTVSplitter | ||||
|   BorderIcons = [biSystemMenu] | ||||
|   Caption = 'IDEOptionsDialog' | ||||
|   ClientHeight = 500 | ||||
| @ -11,41 +12,63 @@ object IDEOptionsDialog: TIDEOptionsDialog | ||||
|   Constraints.MinWidth = 700 | ||||
|   OnShow = FormShow | ||||
|   Position = poScreenCenter | ||||
|   LCLVersion = '0.9.31' | ||||
|   object ButtonPanel: TButtonPanel | ||||
|   object ButtonPanel: TButtonPanel[0] | ||||
|     AnchorSideLeft.Control = Owner | ||||
|     AnchorSideRight.Control = Owner | ||||
|     AnchorSideRight.Side = asrBottom | ||||
|     AnchorSideBottom.Control = Owner | ||||
|     Left = 6 | ||||
|     Height = 34 | ||||
|     Top = 460 | ||||
|     Height = 38 | ||||
|     Top = 456 | ||||
|     Width = 688 | ||||
|     BorderSpacing.Left = 6 | ||||
|     BorderSpacing.Right = 6 | ||||
|     BorderSpacing.Bottom = 6 | ||||
|     BorderSpacing.Around = 0 | ||||
|     OKButton.Name = 'OKButton' | ||||
|     OKButton.DefaultCaption = True | ||||
|     HelpButton.Name = 'HelpButton' | ||||
|     HelpButton.DefaultCaption = True | ||||
|     CloseButton.Name = 'CloseButton' | ||||
|     CloseButton.DefaultCaption = True | ||||
|     CloseButton.Enabled = False | ||||
|     CancelButton.Name = 'CancelButton' | ||||
|     TabOrder = 1 | ||||
|     CancelButton.DefaultCaption = True | ||||
|     TabOrder = 0 | ||||
|     ShowButtons = [pbOK, pbCancel, pbHelp] | ||||
|   end | ||||
|   object CategoryTree: TTreeView | ||||
|     AnchorSideLeft.Control = Owner | ||||
|     AnchorSideTop.Control = Owner | ||||
|     AnchorSideBottom.Control = ButtonPanel | ||||
|     Left = 6 | ||||
|     Height = 454 | ||||
|     Top = 6 | ||||
|     Width = 206 | ||||
|   object CatTVSplitter: TSplitter[1] | ||||
|     Left = 234 | ||||
|     Height = 456 | ||||
|     Top = 0 | ||||
|     Width = 5 | ||||
|   end | ||||
|   object Panel1: TPanel[2] | ||||
|     Left = 0 | ||||
|     Height = 456 | ||||
|     Top = 0 | ||||
|     Width = 234 | ||||
|     Align = alLeft | ||||
|     BorderSpacing.Left = 6 | ||||
|     ClientHeight = 456 | ||||
|     ClientWidth = 234 | ||||
|     TabOrder = 2 | ||||
|     object CategoryTree: TTreeView | ||||
|       AnchorSideLeft.Control = FilterEdit | ||||
|       AnchorSideTop.Control = FilterEdit | ||||
|       AnchorSideTop.Side = asrBottom | ||||
|       AnchorSideRight.Control = Panel1 | ||||
|       AnchorSideRight.Side = asrBottom | ||||
|       AnchorSideBottom.Control = Panel1 | ||||
|       AnchorSideBottom.Side = asrBottom | ||||
|       Left = 7 | ||||
|       Height = 410 | ||||
|       Top = 39 | ||||
|       Width = 220 | ||||
|       Anchors = [akTop, akLeft, akRight, akBottom] | ||||
|       BorderSpacing.Top = 6 | ||||
|       BorderSpacing.Right = 6 | ||||
|       BorderSpacing.Bottom = 6 | ||||
|       Constraints.MinWidth = 206 | ||||
|     DefaultItemHeight = 17 | ||||
|       ReadOnly = True | ||||
|       TabOrder = 0 | ||||
|       OnChange = CategoryTreeChange | ||||
| @ -54,10 +77,19 @@ object IDEOptionsDialog: TIDEOptionsDialog | ||||
|       OnKeyDown = CategoryTreeKeyDown | ||||
|       Options = [tvoAutoItemHeight, tvoHideSelection, tvoKeepCollapsedNodes, tvoReadOnly, tvoShowButtons, tvoShowLines, tvoShowRoot, tvoToolTips, tvoThemedDraw] | ||||
|     end | ||||
|   object CatTVSplitter: TSplitter | ||||
|     Left = 212 | ||||
|     Height = 460 | ||||
|     Top = 0 | ||||
|     Width = 5 | ||||
|     object FilterEdit: TTreeFilterEdit | ||||
|       AnchorSideLeft.Control = Panel1 | ||||
|       Left = 7 | ||||
|       Height = 25 | ||||
|       Top = 8 | ||||
|       Width = 136 | ||||
|       OnFilterItem = FilterEditFilterItem | ||||
|       ButtonWidth = 23 | ||||
|       NumGlyphs = 0 | ||||
|       BorderSpacing.Left = 6 | ||||
|       MaxLength = 0 | ||||
|       TabOrder = 1 | ||||
|       FilteredTreeview = CategoryTree | ||||
|     end | ||||
|   end | ||||
| end | ||||
|  | ||||
| @ -34,7 +34,7 @@ uses | ||||
|   Buttons, ButtonPanel, ExtCtrls, | ||||
|   IDEWindowIntf, IDEOptionsIntf, IDECommands, IDEHelpIntf, | ||||
|   EnvironmentOpts, LazarusIDEStrConsts, | ||||
|   EditorOptions; | ||||
|   EditorOptions, TreeFilterEdit, EditBtn; | ||||
| 
 | ||||
| type | ||||
|   TIDEOptsDlgAction = ( | ||||
| @ -51,10 +51,13 @@ type | ||||
|     ButtonPanel: TButtonPanel; | ||||
|     CategoryTree: TTreeView; | ||||
|     CatTVSplitter: TSplitter; | ||||
|     Panel1: TPanel; | ||||
|     FilterEdit: TTreeFilterEdit; | ||||
|     procedure CategoryTreeChange(Sender: TObject; Node: TTreeNode); | ||||
|     procedure CategoryTreeCollapsed(Sender: TObject; Node: TTreeNode); | ||||
|     procedure CategoryTreeExpanded(Sender: TObject; Node: TTreeNode); | ||||
|     procedure CategoryTreeKeyDown(Sender: TObject; var Key: Word; Shift: TShiftState); | ||||
|     function FilterEditFilterItem(Item: TObject; out Done: Boolean): Boolean; | ||||
|     procedure FormShow(Sender: TObject); | ||||
|     procedure HelpButtonClick(Sender: TObject); | ||||
|     procedure IDEOptionsDialogKeyPress(Sender: TObject; var Key: char); | ||||
| @ -71,6 +74,7 @@ type | ||||
|     SelectNode: TTreeNode; | ||||
|     NewLastSelected: PIDEOptionsEditorRec; | ||||
| 
 | ||||
|     procedure TraverseSettings(AOptions: TAbstractIDEOptions; anAction: TIDEOptsDlgAction); | ||||
|     function CheckValues: boolean; | ||||
|     procedure DoOpenEditor(EditorToOpen: TAbstractIDEOptionsEditorClass); | ||||
|     procedure LoadIDEOptions(Sender: TObject; AOptions: TAbstractIDEOptions); | ||||
| @ -82,7 +86,6 @@ type | ||||
|   public | ||||
|     constructor Create(AOwner: TComponent); override; | ||||
|     function ShowModal: Integer; override; | ||||
| 
 | ||||
|     function AddButton: TBitBtn; override; | ||||
|     function AddControl(AControlClass: TControlClass): TControl; override; | ||||
|     procedure OpenEditor(AEditor: TAbstractIDEOptionsEditorClass); override; | ||||
| @ -90,10 +93,9 @@ type | ||||
|     function FindEditor(AEditor: TAbstractIDEOptionsEditorClass): TAbstractIDEOptionsEditor; override; | ||||
|     function FindEditor(GroupIndex, AIndex: integer): TAbstractIDEOptionsEditor; override; | ||||
|     function FindEditorClass(GroupIndex, AIndex: integer): TAbstractIDEOptionsEditorClass; override; | ||||
|     procedure TraverseSettings(AOptions: TAbstractIDEOptions; anAction: TIDEOptsDlgAction); | ||||
|     procedure ReadAll; | ||||
|     procedure WriteAll(Restore: boolean); | ||||
| 
 | ||||
|   public | ||||
|     property OptionsFilter: TIDEOptionsEditorFilter read FOptionsFilter write FOptionsFilter; | ||||
|     property Settings: TIDEOptionsEditorSettings read FSettings write SetSettings; | ||||
|     property OnLoadIDEOptions: TOnLoadIDEOptions read FOnLoadOptions write FOnLoadOptions; | ||||
| @ -142,17 +144,18 @@ begin | ||||
|   debugln(['TIDEOptionsDialog.IDEOptionsDialogKeyPress ',ord(Key)]); | ||||
| end; | ||||
| 
 | ||||
| procedure TIDEOptionsDialog.CategoryTreeChange(Sender: TObject; | ||||
|   Node: TTreeNode); | ||||
| procedure TIDEOptionsDialog.CategoryTreeChange(Sender: TObject; Node: TTreeNode); | ||||
| var | ||||
|   AEditor: TAbstractIDEOptionsEditor; | ||||
| begin | ||||
|   if Node = nil then Exit; | ||||
|   while Node <> nil do | ||||
|   begin | ||||
|     if Node.Data <> nil then | ||||
|       break; | ||||
|     Node := Node.GetFirstChild; | ||||
|   end; | ||||
|   if Node.Data = nil then Exit; | ||||
| 
 | ||||
|   AEditor := TAbstractIDEOptionsEditor(Node.Data); | ||||
|   NewLastSelected := AEditor.Rec; | ||||
| @ -203,6 +206,17 @@ begin | ||||
|   end; | ||||
| end; | ||||
| 
 | ||||
| function TIDEOptionsDialog.FilterEditFilterItem(Item: TObject; out Done: Boolean): Boolean; | ||||
| var | ||||
|   OptEditor: TAbstractIDEOptionsEditor; | ||||
| begin | ||||
|   Result:=False; | ||||
|   Done:=False;                        // Filter will use also the node caption. | ||||
|   if Item=nil then Exit; | ||||
|   OptEditor:=TAbstractIDEOptionsEditor(Item); | ||||
|   Result:=OptEditor.ContainsTextInCaption(FilterEdit.Filter); | ||||
| end; | ||||
| 
 | ||||
| procedure TIDEOptionsDialog.FormShow(Sender: TObject); | ||||
| begin | ||||
|   // make the category visible in the treeview | ||||
|  | ||||
| @ -25,7 +25,7 @@ unit IDEOptionsIntf; | ||||
| interface | ||||
| 
 | ||||
| uses | ||||
|   Classes, SysUtils, LCLProc, Controls, Buttons, Forms; | ||||
|   Classes, SysUtils, LCLProc, Controls, Buttons, Forms, StdCtrls, Graphics; | ||||
| 
 | ||||
| const | ||||
|   NoParent = -1; | ||||
| @ -122,6 +122,7 @@ type | ||||
|     class function SupportedOptionsClass: TAbstractIDEOptionsClass; virtual; abstract; | ||||
|     class function DefaultCollapseChildNodes: Boolean; virtual; | ||||
|     function FindOptionControl(AClass: TControlClass): TControl; | ||||
|     function ContainsTextInCaption(AText: string): Boolean; | ||||
| 
 | ||||
|     property OnLoadIDEOptions: TOnLoadIDEOptions read FOnLoadIDEOptions write FOnLoadIDEOptions; | ||||
|     property OnSaveIDEOptions: TOnSaveIDEOptions read FOnSaveIDEOptions write FOnSaveIDEOptions; | ||||
| @ -389,8 +390,7 @@ begin | ||||
|   Result := True; | ||||
| end; | ||||
| 
 | ||||
| procedure TAbstractIDEOptionsEditor.RestoreSettings( | ||||
|   AOptions: TAbstractIDEOptions); | ||||
| procedure TAbstractIDEOptionsEditor.RestoreSettings(AOptions: TAbstractIDEOptions); | ||||
| begin | ||||
| 
 | ||||
| end; | ||||
| @ -400,8 +400,7 @@ begin | ||||
|   Result := False; | ||||
| end; | ||||
| 
 | ||||
| function TAbstractIDEOptionsEditor.FindOptionControl(AClass: TControlClass | ||||
|   ): TControl; | ||||
| function TAbstractIDEOptionsEditor.FindOptionControl(AClass: TControlClass): TControl; | ||||
| 
 | ||||
|   function Search(AControl: TControl): TControl; | ||||
|   var | ||||
| @ -424,6 +423,43 @@ begin | ||||
|   Result:=Search(GetParentForm(Self)); | ||||
| end; | ||||
| 
 | ||||
| function TAbstractIDEOptionsEditor.ContainsTextInCaption(AText: string): Boolean; | ||||
| const | ||||
|   FoundColor = clFuchsia; | ||||
| var | ||||
|   UpperText: String; | ||||
| 
 | ||||
|   function Search(AControl: TControl): Boolean; | ||||
|   var | ||||
|     i: Integer; | ||||
|     AWinControl: TWinControl; | ||||
|   begin | ||||
|     if Pos(UpperText, Uppercase(AControl.Caption))>0 then begin | ||||
|       //if Length(UpperText)>2 then | ||||
|       //  DebugLn('TAbstractIDEOptionsEditor.ContainsTextInCaption: Searching "', UpperText, | ||||
|       //          '", Found "', AControl.Caption, '", in ', AControl.Name); | ||||
|       AControl.Font.Color:=FoundColor; | ||||
|       exit(True); | ||||
|     end | ||||
|     else if AControl.Font.Color=FoundColor then | ||||
|       AControl.Font.Color:=clDefault; | ||||
|     if AControl is TWinControl then begin | ||||
|       AWinControl:=TWinControl(AControl); | ||||
|       for i:=0 to AWinControl.ControlCount-1 do | ||||
|         // Memo.Caption return all the lines, skip it. | ||||
|         if not (AWinControl.Controls[i] is TMemo) then begin | ||||
|           Result:=Search(AWinControl.Controls[i]); // Recursive call | ||||
|           if Result then exit; | ||||
|         end; | ||||
|     end; | ||||
|     Result:=False; | ||||
|   end; | ||||
| 
 | ||||
| begin | ||||
|   UpperText:=Uppercase(AText); | ||||
|   Result:=Search(Self); | ||||
| end; | ||||
| 
 | ||||
| { TIDEOptionsEditorList } | ||||
| 
 | ||||
| function TIDEOptionsEditorList.GetItem(AIndex: Integer): PIDEOptionsEditorRec; | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 juha
						juha