mirror of
https://github.com/squidfunk/mkdocs-material.git
synced 2025-01-12 06:02:13 +01:00
280 lines
9.2 KiB
HTML
280 lines
9.2 KiB
HTML
<!--
|
|
Copyright (c) 2016-2017 Martin Donath <martin.donath@squidfunk.com>
|
|
|
|
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
of this software and associated documentation files (the "Software"), to
|
|
deal in the Software without restriction, including without limitation the
|
|
rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
|
|
sell copies of the Software, and to permit persons to whom the Software is
|
|
furnished to do so, subject to the following conditions:
|
|
|
|
The above copyright notice and this permission notice shall be included in
|
|
all copies or substantial portions of the Software.
|
|
|
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT. IN NO EVENT SHALL THE
|
|
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
|
|
FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
|
|
IN THE SOFTWARE.
|
|
-->
|
|
|
|
{% import "partials/i18n.html" as i18n %}
|
|
|
|
<!DOCTYPE html>
|
|
<html class="no-js">
|
|
<head>
|
|
|
|
<!-- Block: metatags -->
|
|
{% block site_meta %}
|
|
<meta charset="utf-8" />
|
|
<meta name="viewport" content="width=device-width, initial-scale=1" />
|
|
|
|
<!-- Site description -->
|
|
{% if config.site_description %}
|
|
<meta name="description" content="{{ config.site_description }}" />
|
|
{% endif %}
|
|
|
|
<!-- Canonical -->
|
|
{% if page.canonical_url %}
|
|
<link rel="canonical" href="{{ page.canonical_url }}" />
|
|
{% endif %}
|
|
|
|
<!-- Author -->
|
|
{% if config.site_author %}
|
|
<meta name="author" content="{{ config.site_author }}" />
|
|
{% endif %}
|
|
|
|
<!-- Favicon -->
|
|
{% if config.site_favicon %}
|
|
<link rel="shortcut icon"
|
|
href="{{ base_url }}/{{ config.site_favicon }}">
|
|
{% else %}
|
|
<link rel="shortcut icon"
|
|
href="{{ base_url }}/assets/images/favicon.ico">
|
|
{% endif %}
|
|
|
|
<!-- Generator banner -->
|
|
<meta name="generator" content="mkdocs+$theme-name$#$theme-version$" />
|
|
{% endblock %}
|
|
|
|
<!-- Block: site title -->
|
|
{% block htmltitle %}
|
|
{% if page.title %}
|
|
<title>{{ page.title }} - {{ config.site_name }}</title>
|
|
{% elif config.site_description %}
|
|
<title>{{ config.site_name }} - {{ config.site_description }}</title>
|
|
{% else %}
|
|
<title>{{ config.site_name }}</title>
|
|
{% endif %}
|
|
{% endblock %}
|
|
|
|
<!-- Block: JavaScript libraries -->
|
|
{% block libs %}
|
|
<script src="{{ base_url }}/assets/javascripts/modernizr.js"></script>
|
|
{% endblock %}
|
|
|
|
<!-- Block: webfonts -->
|
|
{% block fonts %}
|
|
{% include "partials/fonts.html" %}
|
|
{% endblock %}
|
|
|
|
<!-- Block: stylesheets -->
|
|
{% block styles %}
|
|
|
|
<!-- Theme-related stylesheets -->
|
|
<link rel="stylesheet" type="text/css"
|
|
href="{{ base_url }}/assets/stylesheets/application.css" />
|
|
|
|
<!-- Extra color palette -->
|
|
{% if config.extra.palette %}
|
|
<link rel="stylesheet" type="text/css"
|
|
href="{{ base_url }}/assets/stylesheets/application.palette.css" />
|
|
{% endif %}
|
|
|
|
<!-- Custom stylesheets -->
|
|
{% for path in extra_css %}
|
|
<link rel="stylesheet" type="text/css" href="{{ path }}" />
|
|
{% endfor %}
|
|
{% endblock %}
|
|
|
|
<!-- Block: custom front matter -->
|
|
{% block extrahead %}{% endblock %}
|
|
</head>
|
|
|
|
<!-- Integrate color palette, if defined -->
|
|
{% set palette = config.extra.get("palette", {}) %}
|
|
{% set primary = palette.primary | replace(" ", "-") | lower %}
|
|
{% set accent = palette.accent | replace(" ", "-") | lower %}
|
|
{% if primary or accent %}
|
|
<body data-md-color-primary="{{ primary }}"
|
|
data-md-color-accent="{{ accent }}">
|
|
{% else %}
|
|
<body>
|
|
{% endif %}
|
|
|
|
<!-- Inline SVGs -->
|
|
{% include "partials/svgs.html" %}
|
|
|
|
<!-- State toggles -->
|
|
<input class="md-toggle" data-md-toggle="drawer"
|
|
type="checkbox" id="drawer" />
|
|
<input class="md-toggle" data-md-toggle="search"
|
|
type="checkbox" id="search" />
|
|
|
|
<!-- Overlay for expanded drawer -->
|
|
<label class="md-overlay" data-md-component="overlay" for="drawer"></label>
|
|
|
|
<!-- Application header -->
|
|
{% block header %}
|
|
{% include "partials/header.html" %}
|
|
{% endblock %}
|
|
|
|
<!-- Container, necessary for web-application context -->
|
|
<div class="md-container">
|
|
|
|
<!-- Main container -->
|
|
<main class="md-main">
|
|
<div class="md-main__inner md-grid" data-md-component="container">
|
|
|
|
<!-- Block: navigation -->
|
|
{% block site_nav %}
|
|
|
|
<!-- Main navigation -->
|
|
{% if nav %}
|
|
<div class="md-sidebar md-sidebar--primary"
|
|
data-md-component="navigation">
|
|
<div class="md-sidebar__scrollwrap">
|
|
<div class="md-sidebar__inner">
|
|
{% include "partials/nav.html" %}
|
|
</div>
|
|
</div>
|
|
</div>
|
|
{% endif %}
|
|
|
|
<!-- Table of contents -->
|
|
{% if page.toc %}
|
|
<div class="md-sidebar md-sidebar--secondary"
|
|
data-md-component="toc">
|
|
<div class="md-sidebar__scrollwrap">
|
|
<div class="md-sidebar__inner">
|
|
{% include "partials/toc.html" %}
|
|
</div>
|
|
</div>
|
|
</div>
|
|
{% endif %}
|
|
{% endblock %}
|
|
|
|
<!-- Article -->
|
|
<div class="md-content">
|
|
<article class="md-content__inner md-typeset">
|
|
|
|
<!-- Edit button, if URL was defined -->
|
|
{% if config.edit_uri %}
|
|
<a href="{{ page.edit_url }}"
|
|
title="{{ i18n.t('edit.link.title') }}"
|
|
class="md-icon md-content__edit">edit</a>
|
|
{% endif %}
|
|
|
|
<!-- Block: content -->
|
|
{% block content %}
|
|
|
|
<!--
|
|
This is a nasty hack that checks whether the content contains
|
|
a h1 headline. If it doesn't, the page title (or respectively
|
|
site name) is used as the main headline.
|
|
-->
|
|
{% if not "\x3ch1 id=" in page.content %}
|
|
<h1>{{ page.title | default(config.site_name, true)}}</h1>
|
|
{% endif %}
|
|
|
|
<!-- Content -->
|
|
{{ page.content }}
|
|
{% endblock %}
|
|
</article>
|
|
</div>
|
|
</div>
|
|
</main>
|
|
|
|
<!-- Application footer -->
|
|
{% block footer %}
|
|
{% include "partials/footer.html" %}
|
|
{% endblock %}
|
|
</div>
|
|
|
|
<!-- Block: extension- and theme-related JavaScript -->
|
|
{% block scripts %}
|
|
{% for extension in config.markdown_extensions %}
|
|
|
|
<!-- MathJax integration -->
|
|
{% if extension == "pymdownx.arithmatex" %}
|
|
{% set path = "mathjax/latest/MathJax.js?config=TeX-MML-AM_CHTML" %}
|
|
<script src="https://cdn.mathjax.org/{{ path }}"></script>
|
|
{% endif %}
|
|
{% endfor %}
|
|
|
|
<!-- Theme-related and custom JavaScript -->
|
|
<script src="{{ base_url }}/assets/javascripts/application.js"></script>
|
|
<script>
|
|
|
|
/* Configuration for application */
|
|
var config = {
|
|
url: {
|
|
base: "{{ base_url }}",
|
|
}
|
|
};
|
|
|
|
/* Initialize application */
|
|
var app = new Application(config);
|
|
app.initialize();
|
|
</script>
|
|
{% for path in extra_javascript %}
|
|
<script src="{{ path }}"></script>
|
|
{% endfor %}
|
|
{% endblock %}
|
|
|
|
<!-- Block: analytic scripts -->
|
|
{% block analytics %}
|
|
{% if config.google_analytics %}
|
|
<script>
|
|
(function(i,s,o,g,r,a,m){
|
|
i["GoogleAnalyticsObject"]=r;i[r]=i[r]||function(){(i[r].q=i[r].q||
|
|
[]).push(arguments)},i[r].l=1*new Date();a=s.createElement(o),
|
|
m=s.getElementsByTagName(o)[0];a.async=1;a.src=g;
|
|
m.parentNode.insertBefore(a,m)
|
|
})(window, document,
|
|
"script", "https://www.google-analytics.com/analytics.js", "ga");
|
|
|
|
/* General initialization */
|
|
ga("create",
|
|
"{{ config.google_analytics[0] }}",
|
|
"{{ config.google_analytics[1] }}");
|
|
ga("set", "anonymizeIp", true);
|
|
ga("send", "pageview");
|
|
|
|
/* Track outbound links */
|
|
var links = document.getElementsByTagName("a");
|
|
Array.prototype.map.call(links, function(item) {
|
|
if (item.host != document.location.host) {
|
|
item.addEventListener("click", function() {
|
|
var action = item.getAttribute("data-md-action") || "follow";
|
|
ga("send", "event", "outbound", action, item.href);
|
|
});
|
|
}
|
|
});
|
|
|
|
/* Register handler to log search on blur */
|
|
var query = document.forms.search.query;
|
|
query.addEventListener("blur", function() {
|
|
if (this.value) {
|
|
var path = document.location.pathname;
|
|
ga("send", "pageview", path + "?q=" + this.value);
|
|
}
|
|
});
|
|
</script>
|
|
{% endif %}
|
|
{% endblock %}
|
|
</body>
|
|
</html>
|