Menu

[r2591]: / trunk / Src / UDetailPageLoader.pas  Maximize  Restore  History

Download this file

106 lines (87 with data), 3.4 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
{
* This Source Code Form is subject to the terms of the Mozilla Public License,
* v. 2.0. If a copy of the MPL was not distributed with this file, You can
* obtain one at http://mozilla.org/MPL/2.0/
*
* Copyright (C) 2005-2012, Peter Johnson (www.delphidabbler.com).
*
* $Rev$
* $Date$
*
* Heirachy of classes that can produce and load HTML pages displayed in the
* detail panes. Also provides a factory class to create the loader objects.
}
unit UDetailPageLoader;
interface
uses
// Project
Browser.UController, UDetailPageHTML, UView;
type
/// <summary>Generates and displays an HTML page that represents a view.
/// </summary>
/// <remarks>Used to display views in main window's detail pane.</remarks>
TDetailPageLoader = class(TObject)
strict private
var
/// <summary>Web browser control host.</summary>
fWBController: TWBController;
/// <summary>Loads a blank document into a browser control if no document
/// already exists or if forced.</summary>
/// <param name="Reload">Boolean [in] Flag indicating whether HTML document
/// is to be forcibly reloaded (True) or only loading if a document does
/// not yet exist (False).</param>
/// <remarks>Loading a document imports all CSS and JavaScript required for
/// detail pane views.</remarks>
procedure InitBrowser(const Reload: Boolean);
/// <summary>Generates and displays a view in a browser control.</summary>
/// <param name="Generator">TDetailPageHTML [in] Object that generates
/// HTML to be displayed.</param>
/// <remarks>Generated HTML replaces current body of document currently
/// loaded in web browser.</remarks>
procedure DisplayHTML(const Generator: TDetailPageHTML);
public
/// <summary>Constructs object for use with given browser host/controller.
/// </summary>
constructor Create(WBController: TWBController);
/// <summary>Loads an HTML representation of a view into a web browser
/// control.</summary>
/// <param name="View">IView [in] View to be displayed.</param>
/// <param name="Reload">Boolean [in] Flag indicating whether HTML document
/// is to be reloaded (True) or any existing document is to be re-used
/// (False).</param>
procedure LoadPage(View: IView; const Reload: Boolean);
end;
implementation
{ TDetailPageLoader }
constructor TDetailPageLoader.Create(WBController: TWBController);
begin
Assert(Assigned(WBController), ClassName + '.Create: WBController is nil');
inherited Create;
fWBController := WBController;
end;
procedure TDetailPageLoader.DisplayHTML(const Generator: TDetailPageHTML);
var
HTML: string; // HTML to be displayed
begin
HTML := Generator.Generate;
fWBController.IOMgr.ReplaceExistingBodyHTML(HTML);
end;
procedure TDetailPageLoader.InitBrowser(const Reload: Boolean);
begin
if Reload or not fWBController.IOMgr.HTMLDocumentExists then
fWBController.IOMgr.NavigateToResource(HInstance, 'detail.html');
end;
procedure TDetailPageLoader.LoadPage(View: IView; const Reload: Boolean);
var
Generator: TDetailPageHTML; // object used to generate body's inner HTML
begin
Assert(Assigned(View), ClassName + '.LoadPage: View is nil');
InitBrowser(Reload);
Generator := TDetailPageHTMLFactory.CreateGenerator(View);
try
DisplayHTML(Generator);
finally
Generator.Free;
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.