index.html 3.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586
  1. <!-- Индексная страница сайта -->
  2. <html lang="ru">
  3. <head>
  4. <meta charset="utf-8">
  5. <title>test_arch</title>
  6. <meta name="viewport" content="width=device-width, initial-scale=1">
  7. <link href="/static/css/bootstrap.min.css" rel="stylesheet">
  8. <script src="/static/js/htmx.min.js"></script>
  9. </head>
  10. <body class="d-flex flex-column vh-100 overflow-hidden" hx-boost="true">
  11. <header class="shadow-sm container-fluid">
  12. <div class="row">
  13. <div id="header" class="col-2">
  14. <b>GoArch</b><br><strong id="mode"></strong>
  15. </div>
  16. <div id="link" class="col-2">
  17. <button class="btn btn-primary" hx-get="/api/use_case" hx-target="#mode"
  18. hx-trigger="load click">Варианты использования</button>
  19. </div>
  20. <div class="col-1">
  21. <a href="/monitor" class="btn btn-primary" hx-boost="false">Монитор</a>
  22. </div>
  23. </div>
  24. </header>
  25. <!--
  26. <div id="content" class="container-fluid sticky-top">
  27. </div>
  28. -->
  29. <!-- 2. ОСНОВНОЙ КОНТЕНТ (Скроллится)
  30. <div class="container-fluid px-0 mt-5">
  31. <div class="row g-1">
  32. <div class="col-2">
  33. <textarea name="text" class="text-start w-100" rows="40" hx-post="/arch" hx-target="#picture"
  34. hx-trigger="keyup change delay:0.5s">[]</textarea>
  35. </div>
  36. <div class="col-10">
  37. <div id="picture"></div>
  38. </div>
  39. </div>
  40. </div>
  41. -->
  42. <main class="flex-grow-1 overflow-auto px-0">
  43. <div class="container-fluid px-0 h-100">
  44. <div class="row g-4 m-0 h-100"> <!-- m-0 убирает лишний горизонтальный скролл от row -->
  45. <div class="col-2 d-flex">
  46. <!-- rows="20" чтобы точно появился скролл для теста -->
  47. <textarea name="text" class="form-control w-100 flex-grow-1" rows="20" hx-post="/api/arch"
  48. hx-target="#picture" hx-trigger="keyup change delay:0.5s" placeholder="YAML"
  49. style="resize: none;"></textarea>
  50. </div>
  51. <div class="col-10">
  52. <div id="picture" class="w-100 h-100" hx-vals='js:{
  53. "w": document.getElementById("picture").offsetWidth,
  54. "h": document.getElementById("picture").offsetHeight}' hx-post="/api/canvas_size"
  55. hx-trigger="every 250ms" hx-target="#debug-log">
  56. </div>
  57. </div>
  58. </div>
  59. </div>
  60. </main>
  61. <!-- 3. ПОДВАЛ (Всегда снизу)
  62. <div id="footer" class="sticky-bottom">...</div>
  63. -->
  64. <footer class="bg-dark text-white py-2">
  65. <div class="container-fluid text-center">
  66. <div class="row">
  67. <div class="col-2"><small>Футер (не двигается)</small></div>
  68. <div id="debug-log" class="col-10 text-start fs-6 fw-light"></div>
  69. </div>
  70. </div>
  71. </footer>
  72. <script src="/static/js/bootstrap.bundle.min.js"></script>
  73. </body>
  74. </html>