source: cprs/branches/tmg-cprs/CPRS-Chart/TMG_Extra/HTMLEdit/EmbeddedED/KS_Lib.~pas@ 581

Last change on this file since 581 was 541, checked in by Kevin Toppenberg, 15 years ago

TMG Ver 1.1 Added HTML Support, better demographics editing

File size: 10.0 KB
Line 
1{ ******************************************** }
2{ KS_lib ver 1.11 (Jan. 19, 2004) }
3{ }
4{ For Delphi 4, 5 and 6 }
5{ }
6{ Copyright (C) 1999-2003, Kurt Senfer. }
7{ All Rights Reserved. }
8{ }
9{ Support@ks.helpware.net }
10{ }
11{ Documentation and updated versions: }
12{ }
13{ http://KS.helpware.net }
14{ }
15{ ******************************************** }
16{
17 This library is free software; you can redistribute it and/or
18 modify it under the terms of the GNU Lesser General Public
19 License as published by the Free Software Foundation; either
20 version 2.1 of the License, or (at your option) any later version.
21
22 This library is distributed in the hope that it will be useful,
23 but WITHOUT ANY WARRANTY; without even the implied warranty of
24 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
25 Lesser General Public License for more details.
26
27 You should have received a copy of the GNU Lesser General Public
28 License along with this library; if not, write to the Free Software
29 Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
30}
31
32
33unit KS_lib;
34
35 {$I KSED.INC} //Compiler version directives
36
37interface
38
39uses
40 Windows, Messages, SysUtils, Classes, Controls, MSHTML_TLB, Activex;
41
42 procedure SafeYield;
43
44 //function GetDocTypeTag(DOC: IHTMLDocument2): String;
45 function GetHTMLtext(DOC: IHTMLDocument2): String;
46 function GetDocHTML(DOC: IHTMLDocument2): String;
47 function IsFilePath(Url: String; var FilePath: string): HResult;
48 function GetParentElemetType(aTag: IHTMLElement; aType: string; var ParentElement: IHTMLElement): boolean;
49
50const
51 aFilter: string = 'HTML file (*.htm / *.html)|*.htm;*.html|All Files|*.*';
52 AboutBlank: string = 'about:blank';
53 cNormal: String = 'Normal';
54 //cDIV : String = 'DIV';
55 cBODY: string = 'BODY';
56 cTABLE: string = 'TABLE';
57 cTD: string = 'TD';
58 cTH: string = 'TH';
59 cTR: string = 'TR';
60
61
62var
63 FLastError: String;
64
65type
66 CmdID = TOleEnum;
67
68implementation
69
70uses {$IFDEF D6D7} variants, {$ENDIF} AXCtrls, KS_Procs;
71
72
73//------------------------------------------------------------------------------
74function GetParentElemetType(aTag: IHTMLElement; aType: string; var ParentElement: IHTMLElement): boolean;
75begin
76 result := false;
77
78 ParentElement := aTag;
79 if assigned(ParentElement)
80 then begin
81 while (not AnsiSameText(ParentElement.tagName, aType)) and
82 (not SameText(ParentElement.tagName, cBODY)) do
83 begin
84 ParentElement := ParentElement.parentElement;
85 if not assigned(ParentElement)
86 then exit;
87 end;
88
89 result := AnsiSameText(ParentElement.tagName, aType);
90 end;
91
92end;
93//------------------------------------------------------------------------------
94function IsFilePath(Url: String; var FilePath: string): HResult;
95
96 //-----------------------------------------------------
97 function IsFilePath(URN: string): HResult;
98 begin
99 if (length(URN) > 0) and ((copy(URN, 1, 2) = '\\') or (URN[2] = ':'))
100 then begin
101 result := S_OK;
102 FilePath := URN;
103 end
104 else result := S_FALSE;
105 end;
106 //-----------------------------------------------------
107begin
108 //asm int 3 end; //trap
109 { we can have a file path:
110 file://sie01/ksdata/kvalsys/..... or
111 file:///G:/kvalsys/......
112 or a http path and other posibilitys }
113
114 //IsValidURL
115 //CoInternetParseUrl
116 //if(IsValidURL(nil,PWideChar(WideString(aUrl)),0)=S_OK)
117
118 //asm int 3 end; //trap
119
120 result := IsFilePath(URL);
121 if result = S_OK
122 then exit;
123
124 result := S_false;
125
126 if Pos('file:', LowerCase(URL)) = 1
127 then begin
128 FilePath := Copy(URL, 6, Length(URL));
129 if FilePath[1] = '/'
130 then FilePath := StringReplace(FilePath, '/', '\', [rfReplaceAll])
131 else if FilePath[1] <> '\'
132 then exit; //somthings rotten
133
134 if Copy(FilePath, 1, 3) = '\\\' //we have a drive letter type path
135 then delete(FilePath, 1, 3);
136
137 (*
138 //we have to get ried of the first tree \
139 for I := 1 to 3 do
140 Delete(FilePath, 1, pos('\', FilePath));
141 *)
142 result := IsFilePath(FilePath);
143 end;
144end;
145//------------------------------------------------------------------------------
146procedure SafeYield;
147// Make room for other processes
148var
149 Msg : TMsg;
150begin
151 //asm int 3 end; //trap - not used
152 if PeekMessage(Msg, 0, 0, 0, PM_REMOVE)
153 then begin
154 if Msg.Message = wm_Quit
155 then PostQuitMessage(Msg.WParam) //Tell main message loop to terminate
156 else begin
157 TranslateMessage(Msg);
158 DispatchMessage(Msg);
159 end;
160 end;
161end;
162//------------------------------------------------------------------------------
163function GetDocTypeTag(DOC: IHTMLDocument2): String;
164var
165 aElementCollection: IHTMLElementCollection;
166 HTMLElement: IHTMLElement;
167begin
168 //get the <!DOCTYPE tag as the first tag in a collection
169 aElementCollection := (DOC as IHTMLDocument3).getElementsByTagName('!') as IHTMLElementCollection;
170 if aElementCollection.Length > 0
171 then begin
172 HTMLElement := aElementCollection.item(0, null) as IHTMLElement;
173 if (HTMLElement <> Nil) and
174 (pos('<!DOCTYPE', HTMLElement.OuterHTML) = 1)
175 then Result := HTMLElement.OuterHTML
176 else Result := ''; //no <!DOCTYPE tag in this document
177 end
178 else Result := ''; //no <!DOCTYPE tag in this document
179
180end;
181//------------------------------------------------------------------------------
182function GetHTMLtext(DOC: IHTMLDocument2): String;
183//GetHTMLtext takes app. 80 millisec. and GetDocumentHTML app. 70 milisec.
184var
185 aElementCollection: IHTMLElementCollection;
186 HTMLElement: IHTMLElement;
187begin
188 //asm int 3 end; //trap
189
190 if DOC = nil
191 then begin
192 result := '';
193 exit;
194 end;
195
196 //first get the <!DOCTYPE tag - if any
197 result := GetDocTypeTag(DOC);
198
199
200 //get the HTML tag (as a collection of one element)
201 aElementCollection := (DOC as IHTMLDocument3).getElementsByTagName('HTML') as IHTMLElementCollection;
202 if aElementCollection.Length = 1
203 then begin
204 HTMLElement := aElementCollection.item(0, null) as IHTMLElement;
205 if HTMLElement <> Nil
206 //add the HTML tag to the <!DOCTYPE tag (if any)
207 then Result := Result + HTMLElement.OuterHTML
208 else Result := ''; //this is wrong
209 end
210 else Result := ''; //this is wrong
211end;
212//------------------------------------------------------------------------------
213function GetDocHTML(DOC: IHTMLDocument2): String;
214//GetHTMLtext takes app. 80 millisec. and GetDocumentHTML app. 70 milisec.
215
216var
217 aStream: TStringStream;
218 P: PWideChar;
219begin
220 //asm int 3 end; //trap
221
222 if DOC = nil
223 then Result := ''
224 else begin
225 aStream := TStringStream.Create('');
226 try
227
228 { PersistStream.save returns the DHTML tree in the last rendered version
229 Non visible changes isent nessasarely returned
230 PersistFile.Save always returns a rendered document }
231
232 //ForceRendering;
233 //PersistStream.save(TStreamAdapter.Create(AStream), false);
234 //result := aStream.DataString;
235 //S := GetHTMLtext;
236 //waitWhileDocIsBusy;
237 //InsertNewTag2(Doc);
238
239 //waitWhileDocIsBusy;
240 //result := aStream.DataString;
241 //aStream.free;
242 //aStream := TStringStream.Create('');
243
244 (*
245 I := GetTickCount;
246
247 CmdSet(IDM_PERSISTSTREAMSYNC);
248 i := GetTickCount -i;
249 *)
250
251
252 if S_OK = (DOC as IPersistStreamInit).save(TStreamAdapter.Create(AStream), false)
253 then begin
254 //WaitForDocComplete;
255 {this is what DHTMLEDIT does when it is not in preserve Source mode }
256 if aStream.Size = 0 //just in case
257 then begin
258 result := '';
259 exit;
260 end;
261
262 if aStream.DataString[1] = '<'
263 then result := aStream.DataString
264 else begin
265 P := PWideChar(@aStream.DataString[1]) ;
266 result := OleStrToString(P);
267
268 //the aStream.DataString returns a ? in front of the source
269 if (Length(result) > 0) and (Result[1] <> '<')
270 then delete(Result, 1, 1);
271 end;
272 end;
273 finally
274 aStream.free;
275 end;
276 end;
277end;
278//------------------------------------------------------------------------------
279Function ReadRegString(MainKey: HKey; SubKey, ValName: String): String;
280 // NB default value is read if subkey isent ended with a backslash
281Var
282 Key: HKey;
283 C: Array[0..1023] of Char;
284 D: Cardinal; //value type
285 D2: Cardinal; //buffer size
286Begin
287 //asm int 3 end; //trap
288 result := '';
289
290 if RegOpenKeyEx(MainKey, Pchar(NoEndBackSlash(SubKey)), 0, KEY_READ, Key) = ERROR_SUCCESS
291 then begin
292 try
293 C := '';
294 D2 := SizeOf(C);
295 if (RegQueryValueEx(Key, Pchar(ValName), Nil, @D, @C, @D2) = ERROR_SUCCESS) and
296 ((D = REG_EXPAND_SZ) or (D = REG_SZ))
297 then result := C
298 else result := '';
299 finally
300 RegCloseKey(Key);
301 end;
302 end;
303End;
304//------------------------------------------------------------------------------
305end.
Note: See TracBrowser for help on using the repository browser.