backtest-report.html 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224
  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="utf-8">
  5. <meta name="viewport" content="width=device-width, initial-scale=1">
  6. <title>BTC-USDT-SWAP Backtest Report</title>
  7. <style>
  8. body { font-family: Inter, system-ui, sans-serif; margin: 0; background: #f5f1e8; color: #1f1c18; }
  9. .page { max-width: 1280px; margin: 0 auto; padding: 32px 24px 48px; }
  10. .hero { display: flex; justify-content: space-between; gap: 24px; align-items: end; margin-bottom: 24px; }
  11. .hero h1 { margin: 0; font-size: 36px; }
  12. .meta { color: #5f564b; }
  13. .stats { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 12px; margin-bottom: 24px; }
  14. .card { background: #fffdf8; border: 1px solid #d8cdbd; border-radius: 16px; padding: 16px; }
  15. .label { font-size: 12px; letter-spacing: .08em; text-transform: uppercase; color: #7a6f62; margin-bottom: 8px; }
  16. .value { font-size: 28px; font-weight: 700; }
  17. .layout { display: grid; grid-template-columns: 1.1fr .9fr; gap: 16px; }
  18. .panel { background: #fffdf8; border: 1px solid #d8cdbd; border-radius: 18px; padding: 18px; }
  19. table { width: 100%; border-collapse: collapse; font-size: 14px; }
  20. th, td { text-align: left; padding: 10px 8px; border-bottom: 1px solid #ece3d6; }
  21. th { color: #6b6258; font-size: 12px; text-transform: uppercase; letter-spacing: .08em; }
  22. iframe { width: 100%; height: 720px; border: 0; border-radius: 14px; background: white; }
  23. @media (max-width: 960px) {
  24. .stats, .layout { grid-template-columns: 1fr; }
  25. iframe { height: 520px; }
  26. }
  27. </style>
  28. </head>
  29. <body>
  30. <div class="page">
  31. <div class="hero">
  32. <div>
  33. <div class="meta">Journal-first backtest report</div>
  34. <h1>BTC-USDT-SWAP</h1>
  35. </div>
  36. <div class="meta">Bar: 1H · Leverage: 2x</div>
  37. </div>
  38. <div class="stats">
  39. <div class="card">
  40. <div class="label">Return [%]</div>
  41. <div class="value">-12.9</div>
  42. </div>
  43. <div class="card">
  44. <div class="label">Win Rate [%]</div>
  45. <div class="value">42.86</div>
  46. </div>
  47. <div class="card">
  48. <div class="label">Max. Drawdown [%]</div>
  49. <div class="value">-17.93</div>
  50. </div>
  51. <div class="card">
  52. <div class="label"># Trades</div>
  53. <div class="value">14</div>
  54. </div>
  55. </div>
  56. <div class="layout">
  57. <section class="panel">
  58. <h2>Trade Journal</h2>
  59. <table>
  60. <thead>
  61. <tr>
  62. <th>Side</th>
  63. <th>Entry Time</th>
  64. <th>Exit Time</th>
  65. <th>Entry</th>
  66. <th>Exit</th>
  67. <th>PnL</th>
  68. <th>Return %</th>
  69. </tr>
  70. </thead>
  71. <tbody>
  72. <tr>
  73. <td>Short</td>
  74. <td>2026-04-05 06:00</td>
  75. <td>2026-04-05 19:00</td>
  76. <td>66904.3</td>
  77. <td>67387.6</td>
  78. <td>-144.475</td>
  79. <td>-0.72</td>
  80. </tr>
  81. <tr>
  82. <td>Long</td>
  83. <td>2026-04-05 19:00</td>
  84. <td>2026-04-07 02:00</td>
  85. <td>67387.6</td>
  86. <td>68368.0</td>
  87. <td>286.7696</td>
  88. <td>1.45</td>
  89. </tr>
  90. <tr>
  91. <td>Short</td>
  92. <td>2026-04-07 02:00</td>
  93. <td>2026-04-07 23:00</td>
  94. <td>68368.0</td>
  95. <td>71479.0</td>
  96. <td>-923.0247</td>
  97. <td>-4.55</td>
  98. </tr>
  99. <tr>
  100. <td>Long</td>
  101. <td>2026-04-07 23:00</td>
  102. <td>2026-04-08 18:00</td>
  103. <td>71479.0</td>
  104. <td>71854.6</td>
  105. <td>96.8888</td>
  106. <td>0.53</td>
  107. </tr>
  108. <tr>
  109. <td>Short</td>
  110. <td>2026-04-08 18:00</td>
  111. <td>2026-04-09 15:00</td>
  112. <td>71854.6</td>
  113. <td>71090.8</td>
  114. <td>198.0578</td>
  115. <td>1.06</td>
  116. </tr>
  117. <tr>
  118. <td>Long</td>
  119. <td>2026-04-09 15:00</td>
  120. <td>2026-04-10 09:00</td>
  121. <td>71090.8</td>
  122. <td>71581.1</td>
  123. <td>131.2356</td>
  124. <td>0.69</td>
  125. </tr>
  126. <tr>
  127. <td>Short</td>
  128. <td>2026-04-10 09:00</td>
  129. <td>2026-04-10 16:00</td>
  130. <td>71581.1</td>
  131. <td>72418.2</td>
  132. <td>-225.5961</td>
  133. <td>-1.17</td>
  134. </tr>
  135. <tr>
  136. <td>Long</td>
  137. <td>2026-04-10 16:00</td>
  138. <td>2026-04-11 08:00</td>
  139. <td>72418.2</td>
  140. <td>72719.8</td>
  141. <td>78.4617</td>
  142. <td>0.42</td>
  143. </tr>
  144. <tr>
  145. <td>Short</td>
  146. <td>2026-04-11 08:00</td>
  147. <td>2026-04-11 18:00</td>
  148. <td>72719.8</td>
  149. <td>73060.4</td>
  150. <td>-88.9751</td>
  151. <td>-0.47</td>
  152. </tr>
  153. <tr>
  154. <td>Long</td>
  155. <td>2026-04-11 18:00</td>
  156. <td>2026-04-12 04:00</td>
  157. <td>73060.4</td>
  158. <td>71557.6</td>
  159. <td>-387.0868</td>
  160. <td>-2.06</td>
  161. </tr>
  162. <tr>
  163. <td>Short</td>
  164. <td>2026-04-12 04:00</td>
  165. <td>2026-04-13 15:00</td>
  166. <td>71557.6</td>
  167. <td>72347.0</td>
  168. <td>-199.0611</td>
  169. <td>-1.1</td>
  170. </tr>
  171. <tr>
  172. <td>Long</td>
  173. <td>2026-04-13 15:00</td>
  174. <td>2026-04-15 00:00</td>
  175. <td>72347.0</td>
  176. <td>74100.0</td>
  177. <td>427.5799</td>
  178. <td>2.42</td>
  179. </tr>
  180. <tr>
  181. <td>Short</td>
  182. <td>2026-04-15 00:00</td>
  183. <td>2026-04-15 21:00</td>
  184. <td>74100.0</td>
  185. <td>74794.4</td>
  186. <td>-173.3802</td>
  187. <td>-0.94</td>
  188. </tr>
  189. <tr>
  190. <td>Long</td>
  191. <td>2026-04-15 21:00</td>
  192. <td>2026-04-16 14:00</td>
  193. <td>74794.4</td>
  194. <td>73750.0</td>
  195. <td>-253.5064</td>
  196. <td>-1.4</td>
  197. </tr>
  198. </tbody>
  199. </table>
  200. </section>
  201. <section class="panel">
  202. <h2>Chart</h2>
  203. <iframe src="/files/backtest-report.plot.html" title="Backtest Plot"></iframe>
  204. </section>
  205. </div>
  206. </div>
  207. </body>
  208. </html>