base.html 2.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455
  1. <!DOCTYPE html>
  2. <html lang="{{ lang }}" data-base-path="{{ site.base_path }}">
  3. <head>
  4. <meta charset="utf-8">
  5. <meta name="viewport" content="width=device-width, initial-scale=1">
  6. <title>{{ page.title }} - {{ site.title }}</title>
  7. <link rel="stylesheet" href="{{ site.base_path }}/css/main.css">
  8. <script>
  9. (function() {
  10. var t = localStorage.getItem('preferred-theme');
  11. if (!t) t = window.matchMedia('(prefers-color-scheme: light)').matches ? 'light' : 'dark';
  12. if (t === 'light') document.documentElement.setAttribute('data-theme', 'light');
  13. })();
  14. </script>
  15. </head>
  16. <body>
  17. <header class="header">
  18. <div class="header-inner">
  19. <a href="{{ site.base_path }}/{{ lang }}/" class="header-title">{{ site.title }}{% if site.version %} <span style="font-size:0.75em;font-weight:normal;margin-left:4px">v{{ site.version }}</span>{% endif %}</a>
  20. <div class="header-spacer"></div>
  21. <nav class="header-nav">
  22. <a href="{{ site.base_path }}/{{ lang }}/">Home</a>
  23. <a href="{{ site.base_path }}/{{ lang }}/tour/">Tour</a>
  24. <a href="https://github.com/yhirose/cpp-httplib">GitHub</a>
  25. </nav>
  26. <div class="header-tools">
  27. <button class="theme-toggle" aria-label="Toggle theme"></button>
  28. <div class="lang-selector">
  29. <button class="lang-btn" aria-label="Language">{{ lang | upper }}</button>
  30. <ul class="lang-popup">
  31. {% for l in site.langs %}
  32. <li><a href="#" data-lang="{{ l }}">{{ l | upper }}</a></li>
  33. {% endfor %}
  34. </ul>
  35. </div>
  36. </div>
  37. {% block sidebar_toggle %}{% endblock %}
  38. </div>
  39. </header>
  40. {% if page.status == "draft" %}
  41. <div class="draft-banner">DRAFT</div>
  42. {% endif %}
  43. <div class="layout {% block layout_class %}{% endblock %}">
  44. {% block body %}{% endblock %}
  45. </div>
  46. <footer class="footer">
  47. &copy; 2026 yhirose. All rights reserved.
  48. </footer>
  49. <script src="{{ site.base_path }}/js/main.js"></script>
  50. </body>
  51. </html>