Menu

[r3136]: / branches / 3.x / Src / FrInfo.pas  Maximize  Restore  History

Download this file

203 lines (179 with data), 7.2 kB

  1
  2
  3
  4
  5
  6
  7
  8
  9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
{
* FrInfo.pas
*
* Frame that displays and manages user interaction with the pane that displays
* details of routines and other selected view items.
*
* $Rev$
* $Date$
*
* ***** BEGIN LICENSE BLOCK *****
*
* Version: MPL 1.1
*
* The contents of this file are subject to the Mozilla Public License Version
* 1.1 (the "License"); you may not use this file except in compliance with the
* License. You may obtain a copy of the License at http://www.mozilla.org/MPL/
*
* Software distributed under the License is distributed on an "AS IS" basis,
* WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License for
* the specific language governing rights and limitations under the License.
*
* The Original Code is FrInfo.pas
*
* The Initial Developer of the Original Code is Peter Johnson
* (http://www.delphidabbler.com/).
*
* Portions created by the Initial Developer are Copyright (C) 2005-2010 Peter
* Johnson. All Rights Reserved.
*
* Contributors:
* NONE
*
* ***** END LICENSE BLOCK *****
}
unit FrInfo;
interface
uses
// Delphi
OleCtrls, SHDocVw, Classes, Controls, ExtCtrls,
// Project
FrDetailView, IntfFrameMgrs, IntfHTMLDocHostInfo, UActiveTextHTML,
UCSSBuilder, UDetailPageLoader, USearch;
type
{
TInfoFrame:
Frame that displays and manages user interaction with the pane that displays
details of snippets and other selected view items. It implements display
manager, clipboard manager and selection manager interfaces. It also manages
the contained web browser control and provides an extension to the browser's
"external" object via its ISetWBExternal interface.
}
TInfoFrame = class(TDetailViewFrame,
IWBDisplayMgr, // support for hosted browser control
IViewItemDisplayMgr, // displays a view item
IPaneInfo, // provides information about pane
IWBCustomiser, // customises web browser control
IClipboardMgr, // clipboard manager
ISelectionMgr, // selection manager
IHTMLDocHostInfo // info for use in HTML manipulation
)
protected // do not make strict
{ IWBDisplayMgr: Implemented in ancestor class }
{ IViewItemDisplayMgr: Implemented in ancestor class }
{ IPaneInfo: Implemented in ancestor class }
{ IWBCustomiser: Implemented in ancestor class }
{ IClipboardMgr: Implemented in ancestor class }
{ ISelectionMgr: Implemented in ancestor class } // selection manager
{ IHTMLDocHostInfo: Implemented in ancestor class }
strict protected
procedure BuildCSS(const CSSBuilder: TCSSBuilder); override;
{Generates CSS classes specific to HTML displayed in information pane.
This CSS is added to that provided by parent class.
@param CSSBuilder [in] Object used to build the CSS code.
}
procedure HighlightSearchResults(const Criteria: ITextSearchCriteria);
{Highlights words in current snippet document that match text search
criteria.
@param Criteria [in] Text search criteria.
}
function GetPageKind: TDetailPageKind; override;
{Gets page kind and provides to base class.
@return Page kind.
}
procedure DisplayCurViewItem; override;
{Displays current view item. This method should not be called directly
from this class. Instead call inherited UpdateDisplay method which first
checks if frame is active before calling this method polymorphically.
}
end;
implementation
uses
// Delphi
SysUtils, Graphics,
// Project
Browser.UHighlighter, UColours, UCSSUtils, UFontHelper, UQuery, UView;
{$R *.dfm}
{ TInfoFrame }
procedure TInfoFrame.BuildCSS(const CSSBuilder: TCSSBuilder);
{Generates CSS classes specific to HTML displayed in information pane. This
CSS is added to that provided by parent class.
@param CSSBuilder [in] Object used to build the CSS code.
}
var
ContentFont: TFont; // default content font for OS
begin
// NOTE:
// We only set CSS properties that may need to use system colours or fonts
// that may be changed by user or changing program defaults. CSS that controls
// layout remains in a CSS file embedded in resources.
inherited;
// Add CSS relating to compiler table
with CSSBuilder.AddSelector('.comptable th') do
begin
AddProperty(CSSBackgroundColorProp(clCompTblHeadBg));
AddProperty(CSSFontWeightProp(cfwNormal));
end;
ContentFont := TFont.Create;
try
// Add CSS relating to Extra REML code
TFontHelper.SetContentFont(ContentFont, True);
TActiveTextHTML.Styles(ContentFont, CSSBuilder);
finally
FreeAndNil(ContentFont);
end;
end;
procedure TInfoFrame.DisplayCurViewItem;
{Displays current view item. This method should not be called directly from
this class. Instead call inherited UpdateDisplay method which first checks if
frame is active before calling this method polymorphically.
}
var
TextSearchCriteria: ITextSearchCriteria; // criteria for any text search
begin
inherited; // Load page and update dynamically as required
// If we're viewing a snippet and there's an active text search, highlight
// text that matches search
if (CurrentView.Kind = vkRoutine) and
Supports(
Query.CurrentSearch.Criteria, ITextSearchCriteria, TextSearchCriteria
) then
HighlightSearchResults(TextSearchCriteria);
end;
function TInfoFrame.GetPageKind: TDetailPageKind;
{Gets page kind and provides to base class.
@return Page kind.
}
begin
Result := pkInfo;
end;
procedure TInfoFrame.HighlightSearchResults(
const Criteria: ITextSearchCriteria);
{Highlights words in current snippet document that match text search criteria.
@param Criteria [in] Text search criteria.
}
var
Highlighter: TWBHighlighter; // object used to perform highlighting
begin
Assert(Assigned(Criteria),
ClassName + '.HighlightSearchResults: Criteria is nil');
Assert(Supports(Criteria, ITextSearchCriteria),
ClassName + '.HighlightSearchResults: There is no current text search');
Assert(CurrentView.Kind = vkRoutine,
ClassName + '.HighlightSearchResults: View item is not a snippet');
// Create and configure highlighter object
Highlighter := TWBHighlighter.Create(wbBrowser);
try
// only a snippet's description and source code are included in a text
// search. These sections are enclosed in tags with ids 'description',
// 'sourcecode' and 'extra' respectively in the document's HTML so we
// restrict highlighting to these sections
Highlighter.SearchSectionIDs.Add('description');
Highlighter.SearchSectionIDs.Add('sourcecode');
Highlighter.SearchSectionIDs.Add('extra');
Highlighter.HighlightSearchResults(Criteria);
finally
FreeAndNil(Highlighter);
end;
end;
end.
Want the latest updates on software, tech news, and AI?
Get latest updates about software, tech news, and AI from SourceForge directly in your inbox once a month.