Menu

[r107]: / trunk / Src / FrInfo.pas  Maximize  Restore  History

Download this file

286 lines (262 with data), 12.0 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
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
{
* FrInfo.pas
*
* Frame that displays and manages user interaction with the pane that displays
* details of routines and other selected view items.
*
* v0.1 of 30 Jan 2005 - Original version.
* v0.2 of 18 Feb 2005 - Deleted unused units from uses clauses.
* v0.3 of 19 Feb 2005 - Refactoring: changed frame to implement the renamed
* IFrameActionMgr and IInfoActionMgr interfaces.
* v0.4 of 20 Feb 2005 - Significantly revised method to generating and
* displaying HTML pages by using new TDetailPageLoader
* classes.
* v0.5 of 22 Feb 2005 - Modified to use new browser external object extender.
* - Single extender object now supplied to frame (by
* calling its new ISetWBExternal interface) rather than
* frame owning its own custom extender object.
* - All support for IFrameActionMgr interfaces deleted
* since the new extender object handles notification of
* user-initiated events to application.
* v0.6 of 23 Feb 2005 - Significantly revised to descend from other frames
* that implement functionality that is common to all
* detail view frames. This frame now only implements
* functions specific to the information frame.
* v0.7 of 28 Feb 2005 - Added support for highlighting found text in current
* document. Uses object in new UWBHighlighter unit to
* perform highlighting.
* v0.8 of 16 Apr 2006 - Removed ISetWBExternal interface and replaced with new
* IWBCustomiser interface to perform web browser
* customisation. IWBCustomiser methods implemented in
* ancestor class.
* v1.0 of 25 May 2006 - Improved and corrected comments.
* v1.1 of 03 Dec 2006 - Added support for dynamically updating display via
* DHTML.
* - Added GetPageKind override to return page kind to base
* class to enable it to display correct view.
* - Changed DisplayCurViewItem to override new version in
* base class to perform any required text search
* highlighting.
* - Added code to set CSS specific to information pane.
* v1.2 of 04 Feb 2007 - Now uses global query object to find details of
* current search query rather than use TDetailView
* object.
* - Added new parameter to TInfoFrame.Display to force
* redisplay of view item even if already displayed. This
* was done to enable pane to highlight or unhilight text
* search results. We previously used a TDetailView
* object to do this.
* - Replaced now redundant TDetailView class references
* with TViewItem.
* v1.3 of 16 Feb 2007 - Revised to work with redefined display interfaces from
* IntfFrameMgrs.
* - Pushed Display method back into base class.
* v1.4 of 15 Oct 2007 - Added "extras" division to list of divs that are
* highlighted by text search highlighter.
* v1.5 of 05 Nov 2007 - Changed to use revised CSS builder classes.
* v1.6 of 19 Jan 2009 - Changed to support interfaces from IntfHTMLDocHostInfo
* to replace those deleted from UDHTML.
* - Made a protected section strict.
* - ClassName method now provides class name in asserts.
* v1.7 of 20 Jun 2009 - Removed frame's support for IInfoRoutineHostInfo and
* IDetailViewHostInfo interfaces.
* - Added CSS relating to HTML used to render REML tags
* used when displaying Extra information.
*
*
* ***** 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-2009 Peter
* Johnson. All Rights Reserved.
*
* ***** END LICENSE BLOCK *****
}
unit FrInfo;
interface
uses
// Delphi
OleCtrls, SHDocVw, Classes, Controls, ExtCtrls,
// Project
FrDetailView, IntfFrameMgrs, IntfHTMLDocHostInfo, 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
UColours, UCSSUtils, UFontHelper, UQuery, UWBHighlighter, 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
MonoFont: TFont; // default mono spaced 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;
// Add CSS relating to Extra REML code
// -- heading tag
with CSSBuilder.AddSelector('h2.extra') do
begin
ContentFont := TFont.Create;
try
TFontHelper.SetContentFont(Font, True);
Font.Size := Font.Size + 1;
AddProperty(CSSFontSizeProp(Font.Size));
finally
FreeAndNil(ContentFont);
end;
end;
// -- warning tag
with CSSBuilder.AddSelector('span.extra-warning') do
begin
AddProperty(CSSFontWeightProp(cfwBold));
AddProperty(CSSColorProp(clWarningText));
end;
// -- mono tag
with CSSBuilder.AddSelector('span.extra-mono') do
begin
MonoFont := TFont.Create;
try
TFontHelper.SetDefaultMonoFont(MonoFont, True);
AddProperty(CSSFontProps(MonoFont));
finally
FreeAndNil(MonoFont);
end;
end;
// -- var tag
with CSSBuilder.AddSelector('var.extra') do
begin
AddProperty(CSSColorProp(clVarText));
AddProperty(CSSFontStyleProp(cfsItalic));
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.