2012-03-09 17:44:14 +01:00
|
|
|
{% extends "basic/layout.html" %}
|
|
|
|
{% set script_files = script_files + ['_static/bootstrap-dropdown.js', '_static/bootstrap-scrollspy.js'] %}
|
2013-02-24 13:20:16 +01:00
|
|
|
{% set css_files = ['_static/bootstrap.css', '_static/bootstrap-sphinx.css', '_static/ansible-local.css'] + css_files %}
|
2012-03-09 17:44:14 +01:00
|
|
|
|
|
|
|
{# Sidebar: Rework into our Boostrap nav section. #}
|
|
|
|
{% macro navBar() %}
|
|
|
|
<div class="topbar" data-scrollspy="scrollspy" >
|
|
|
|
<div class="topbar-inner">
|
|
|
|
<div class="container">
|
2012-10-17 00:00:41 +02:00
|
|
|
<!-- <a class="brand" href="{{ pathto(master_doc) }}">{{ shorttitle|e }}</a> -->
|
2012-03-09 17:44:14 +01:00
|
|
|
<ul class="nav">
|
|
|
|
{% block sidebartoc %}
|
2012-09-24 02:43:01 +02:00
|
|
|
<li><a href="/">Home</A>
|
|
|
|
{% include "globaltoc.html" %}
|
2012-03-31 15:36:37 +02:00
|
|
|
{% include "localtoc.html" %}
|
2012-03-09 17:44:14 +01:00
|
|
|
{% endblock %}
|
|
|
|
</ul>
|
|
|
|
<ul class="nav secondary-nav">
|
|
|
|
{% block sidebarsearch %}
|
|
|
|
{% include "searchbox.html" %}
|
|
|
|
{% endblock %}
|
|
|
|
</ul>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
{% endmacro %}
|
2012-09-24 02:43:01 +02:00
|
|
|
<p></p>
|
2012-03-09 17:44:14 +01:00
|
|
|
|
|
|
|
{%- block extrahead %}
|
|
|
|
<script type="text/javascript">
|
|
|
|
(function () {
|
|
|
|
/**
|
|
|
|
* Patch TOC list.
|
|
|
|
*
|
|
|
|
* Will mutate the underlying span to have a correct ul for nav.
|
|
|
|
*
|
|
|
|
* @param $span: Span containing nested UL's to mutate.
|
|
|
|
* @param minLevel: Starting level for nested lists. (1: global, 2: local).
|
|
|
|
*/
|
|
|
|
var patchToc = function ($span, minLevel) {
|
|
|
|
var $tocList = $("<ul/>").attr('class', "dropdown-menu"),
|
|
|
|
findA;
|
|
|
|
|
|
|
|
// Find all a "internal" tags, traversing recursively.
|
|
|
|
findA = function ($elem, level) {
|
|
|
|
var level = level || 0,
|
|
|
|
$items = $elem.find("> li > a.internal, > ul, > li > ul");
|
|
|
|
|
|
|
|
// Iterate everything in order.
|
|
|
|
$items.each(function (index, item) {
|
|
|
|
var $item = $(item),
|
|
|
|
tag = item.tagName.toLowerCase(),
|
|
|
|
pad = 10 + ((level - minLevel) * 10);
|
|
|
|
|
|
|
|
if (tag === 'a' && level >= minLevel) {
|
|
|
|
// Add to existing padding.
|
|
|
|
$item.css('padding-left', pad + "px");
|
|
|
|
// Add list element.
|
|
|
|
$tocList.append($("<li/>").append($item));
|
|
|
|
} else if (tag === 'ul') {
|
|
|
|
// Recurse.
|
|
|
|
findA($item, level + 1);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
|
|
|
// Start construction and return.
|
|
|
|
findA($span);
|
|
|
|
|
|
|
|
// Wipe out old list and patch in new one.
|
|
|
|
return $span.empty("ul").append($tocList);
|
|
|
|
};
|
|
|
|
|
|
|
|
$(document).ready(function () {
|
|
|
|
// Patch the global and local TOC's to be bootstrap-compliant.
|
|
|
|
patchToc($("span.globaltoc"), 1);
|
|
|
|
patchToc($("span.localtoc"), 2);
|
|
|
|
|
|
|
|
// Activate.
|
|
|
|
$('#topbar').dropdown();
|
|
|
|
});
|
|
|
|
}());
|
2012-03-10 04:31:54 +01:00
|
|
|
</script>
|
2012-04-28 16:46:09 +02:00
|
|
|
|
2012-03-10 04:31:54 +01:00
|
|
|
<script type="text/javascript">
|
|
|
|
|
|
|
|
var _gaq = _gaq || [];
|
|
|
|
_gaq.push(['_setAccount', 'UA-29861888-1']);
|
|
|
|
_gaq.push(['_trackPageview']);
|
|
|
|
|
|
|
|
(function() {
|
|
|
|
var ga = document.createElement('script'); ga.type =
|
|
|
|
'text/javascript'; ga.async = true;
|
|
|
|
ga.src = ('https:' == document.location.protocol ? 'https://ssl' :
|
|
|
|
'http://www') + '.google-analytics.com/ga.js';
|
|
|
|
var s = document.getElementsByTagName('script')[0];
|
|
|
|
s.parentNode.insertBefore(ga, s);
|
|
|
|
})();
|
|
|
|
|
2013-02-24 13:20:16 +01:00
|
|
|
</script>
|
|
|
|
<script type="text/javascript">
|
|
|
|
// Set the maximum height of drop down menus to just less than the height
|
|
|
|
// of the viewport.
|
|
|
|
var set_max_menu_height = function () {
|
|
|
|
|
|
|
|
// set menu max height to 75 less than viewport height
|
|
|
|
$('.dropdown-menu').css('max-height', $(window).height() - 75);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Set this when we set the page up and on each resize.
|
|
|
|
$(window).resize(set_max_menu_height);
|
|
|
|
$(window).ready(set_max_menu_height);
|
|
|
|
|
2012-03-09 17:44:14 +01:00
|
|
|
</script>
|
2012-04-28 16:46:09 +02:00
|
|
|
|
2012-03-09 17:44:14 +01:00
|
|
|
{% endblock %}
|
|
|
|
|
|
|
|
{% block header %}{{ navBar() }}{% endblock %}
|
|
|
|
|
|
|
|
{# Silence the sidebar's, relbar's #}
|
|
|
|
{% block sidebar1 %}{% endblock %}
|
|
|
|
{% block sidebar2 %}{% endblock %}
|
|
|
|
{% block relbar1 %}{% endblock %}
|
|
|
|
{% block relbar2 %}{% endblock %}
|
|
|
|
|
|
|
|
{%- block content %}
|
2012-03-10 16:39:34 +01:00
|
|
|
|
2012-03-09 17:44:14 +01:00
|
|
|
<div class="container">
|
|
|
|
{% block body %} {% endblock %}
|
2012-04-28 16:42:32 +02:00
|
|
|
<br/>
|
2012-03-09 17:44:14 +01:00
|
|
|
</div>
|
2012-10-10 14:03:52 +02:00
|
|
|
|
2012-03-09 17:44:14 +01:00
|
|
|
{%- endblock %}
|
|
|
|
|
|
|
|
{%- block footer %}
|
2012-04-28 16:53:15 +02:00
|
|
|
<footer class="footer">
|
2012-04-28 16:50:20 +02:00
|
|
|
<p>
|
2012-03-09 17:44:14 +01:00
|
|
|
{%- if show_copyright %}
|
|
|
|
{%- if hasdoc('copyright') %}
|
|
|
|
{% trans path=pathto('copyright'), copyright=copyright|e %}© <a href="{{ path }}">Copyright</a> {{ copyright }}.{% endtrans %}<br/>
|
|
|
|
{%- else %}
|
|
|
|
{% trans copyright=copyright|e %}© Copyright {{ copyright }}.{% endtrans %}<br/>
|
|
|
|
{%- endif %}
|
|
|
|
{%- endif %}
|
|
|
|
{%- if last_updated %}
|
|
|
|
{% trans last_updated=last_updated|e %}Last updated on {{ last_updated }}.{% endtrans %}<br/>
|
|
|
|
{%- endif %}
|
|
|
|
</p>
|
2012-09-28 03:33:55 +02:00
|
|
|
</div>
|
2012-03-09 17:44:14 +01:00
|
|
|
</footer>
|
|
|
|
{%- endblock %}
|
|
|
|
|