browserconsole.pas 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151
  1. unit browserconsole;
  2. {$mode objfpc}
  3. interface
  4. uses
  5. js,web, sysutils;
  6. Const
  7. BrowserLineBreak = #10;
  8. DefaultMaxConsoleLines = 25;
  9. DefaultConsoleStyle = '.pasconsole { '+BrowserLineBreak+
  10. 'font-family: courier;'+BrowserLineBreak+
  11. 'font-size: 14px;'+BrowserLineBreak+
  12. 'background: #FFFFFF;'+BrowserLineBreak+
  13. 'color: #000000;'+BrowserLineBreak+
  14. 'display: block;'+BrowserLineBreak+
  15. '}';
  16. DefaultCRTConsoleStyle = '.pasconsole { '+BrowserLineBreak+
  17. 'font-family: courier;'+BrowserLineBreak+
  18. 'font-size: 14px;'+BrowserLineBreak+
  19. 'background: #000;'+BrowserLineBreak+
  20. 'color: #14fdce;'+BrowserLineBreak+
  21. 'display: block;'+BrowserLineBreak+
  22. '}';
  23. Var
  24. // Element ID for console output. If this is not set, body is used.
  25. // If you cange this, call HookConsole.
  26. ConsoleElementID : String;
  27. // Style to use for console lines. If you change this, call initconsole
  28. ConsoleStyle : String;
  29. // Style to use for console lines. You can change this at any time.
  30. MaxConsoleLines : Integer;
  31. // Copy console lines on newline to browser console log
  32. ConsoleLinesToBrowserLog : Boolean;
  33. // Clear console content
  34. Procedure ResetConsole;
  35. // Re-initialize console (style)
  36. Procedure InitConsole;
  37. // Re-hook console
  38. Procedure HookConsole;
  39. implementation
  40. Var
  41. LastLine,
  42. StyleElement,
  43. LinesParent,
  44. ConsoleElement : TJSElement;
  45. Procedure AppendLine;
  46. Var
  47. CurrentCount : Integer;
  48. S : TJSNode;
  49. begin
  50. CurrentCount:=0;
  51. S:=LinesParent.firstChild;
  52. While Assigned(S) do
  53. begin
  54. Inc(CurrentCount);
  55. S:=S.nextSibling;
  56. end;
  57. While CurrentCount>MaxConsoleLines do
  58. begin
  59. Dec(CurrentCount);
  60. LinesParent.removeChild(LinesParent.firstChild);
  61. end;
  62. LastLine:=Document.createElement('div');
  63. LastLine.className:='pasconsole';
  64. LinesParent.AppendChild(LastLine);
  65. end;
  66. Procedure WriteConsole(S : JSValue; NewLine : Boolean);
  67. Var
  68. CL: String;
  69. begin
  70. CL:=LastLine.InnerHtml;
  71. CL:=CL+String(S);
  72. cl:=StringReplace(cl,' ',' ',[rfReplaceAll]);
  73. cl:=StringReplace(cl,#13#10,'<br>',[rfReplaceAll]);
  74. cl:=StringReplace(cl,#10,'<br>',[rfReplaceAll]);
  75. cl:=StringReplace(cl,#10,'<br>',[rfReplaceAll]);
  76. LastLine.InnerHtml:=CL;
  77. if NewLine then
  78. begin
  79. if ConsoleLinesToBrowserLog then
  80. console.log(LastLine.InnerText);
  81. AppendLine;
  82. end;
  83. end;
  84. Procedure ResetConsole;
  85. begin
  86. if LinesParent=Nil then exit;
  87. While LinesParent.firstElementChild<>Nil do
  88. LinesParent.removeChild(LinesParent.firstElementChild);
  89. AppendLine;
  90. end;
  91. Procedure InitConsole;
  92. begin
  93. if ConsoleElement=Nil then
  94. exit;
  95. if (TJSString(ConsoleElement.nodeName).toLowerCase<>'body') then
  96. begin
  97. While ConsoleElement.firstElementChild<>Nil do
  98. ConsoleElement.removeChild(ConsoleElement.firstElementChild);
  99. end;
  100. StyleElement:=Document.createElement('style');
  101. StyleElement.innerText:=ConsoleStyle;
  102. ConsoleElement.appendChild(StyleElement);
  103. LinesParent:=Document.createElement('div');
  104. ConsoleElement.appendChild(LinesParent);
  105. end;
  106. Procedure HookConsole;
  107. begin
  108. ConsoleElement:=Nil;
  109. if (ConsoleElementID<>'') then
  110. ConsoleElement:=document.getElementById(ConsoleElementID);
  111. if (ConsoleElement=Nil) then
  112. ConsoleElement:=document.body;
  113. if ConsoleElement=Nil then
  114. exit;
  115. InitConsole;
  116. ResetConsole;
  117. SetWriteCallBack(@WriteConsole);
  118. end;
  119. initialization
  120. ConsoleLinesToBrowserLog:=True;
  121. ConsoleElementID:='pasjsconsole';
  122. ConsoleStyle:=DefaultConsoleStyle;
  123. MaxConsoleLines:=DefaultMaxConsoleLines;
  124. HookConsole;
  125. end.