123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277 |
- /*custom webhelp*/
- var windowheight = $( window ).height();
- var windowwidth = $( window ).width();
- $( document ).ready(function() {
- /*adjust dev branch notification*/
- if ($( '#dev-notification' ).length ) {
- $( '#dev-notification', '.dev-notification-text' ).width($( '.navbar-header' ).width());
- $( '.navbar-header' ).css("padding-top", $( '#dev-notification' ).height() + 10);
- }
- /*insert links to module functions*/
- if ($( 'a.current' ).length && $( 'dt .headerlink' ).length ) {
- if (window.location.href.indexOf('/ref/cli/') == -1) {
- var tgt = $( 'a.current' );
- tgt.after('<ul id="function-list"></ul>');
- $('dt .headerlink').each(function(idx, elem) {
- var i = [
- '<li><a class="function-nav-link" href="', elem.href, '">',
- last(elem.href.split('.')),
- '</a></li>']
- .join('');
- $( '#function-list' ).append(i);
- });
- }
- }
- /*scroll the right-hand navigation*/
- //var wheight = $( window ).height() - $( '#sidebar-static' ).height() - $( '#sidebar-static-bottom' ).height();
- var wheight = $( window ).height() - 160;
- $(function(){
- $( '#sidebar-nav' ).slimScroll({
- width: 'inherit',
- size: '14px',
- height: wheight
- }).promise().done(function() {
- if (window.location.hash) {
- var hash = window.location.hash.substring(1);
- var $link = $( '#sidebar-nav').find('a[href$="#' + hash + '"]').addClass("selected");
- if ($link.length) {
- var scrollTo_val = $link.offset().top - ($( '#sidebar-static' ).height() + 200) + 'px';
- $( '#sidebar-nav' ).slimScroll({ scrollTo : scrollTo_val });
- }
- else if ($( 'a.current' ).length) {
- var scrollTo_val = $( 'a.current' ).offset().top - ($( '#sidebar-static' ).height() + 200) + 'px';
- $( '#sidebar-nav' ).slimScroll({ scrollTo : scrollTo_val });
- }
- }
- else if ($( 'a.current' ).length) {
- var scrollTo_val = $( 'a.current' ).offset().top - ($( '#sidebar-static' ).height() + 200) + 'px';
- $( '#sidebar-nav' ).slimScroll({ scrollTo : scrollTo_val });
- }
- /*hidden by css - make visible after slimScroll plug-in loads*/
- $( '#sidebar-wrapper').css('visibility','visible');
- });
- });
- /*permalink display*/
- $( 'a.headerlink').html( '<span class="permalink"><i data-container="body" data-toggle="tooltip" data-placement="bottom" title="Link to this location" class="glyphicon glyphicon-link"></i></span>');
- $( 'h1,h2,h3,h4,h5,h6').mouseenter(function(){
- $(this).find( '.permalink' ).find( 'i' ).css({'color':'#000'});
- }).mouseleave(function(){
- $(this).find( '.permalink' ).find( 'i' ).css({'color':'#fff'});
- });
- /*smooth on-page scrolling for long topic*/
- $( '#sidebar-nav' ).on('click','a[href^="#"]',function (e) {
- e.preventDefault();
- $( '#sidebar-nav' ).find( 'a' ).removeClass('selected');
- $(this).addClass('selected');
- var target = this.hash;
- var $target = $(target);
- $('html, body').stop().animate({
- 'scrollTop': $target.offset().top + 200
- }, 900, 'swing', function () {
- window.location.hash = target;
- });
- });
- /*scroll to active topic*/
- $( '#sidebar-nav' ).on('click','a.function-nav-link',function (e) {
- e.preventDefault();
- $( 'a.function-nav-link' ).removeClass('selected');
- $(this).addClass('selected');
- var target = this.hash.substring(1);
- var $target = $('dt[id="' + target + '"]');
- $('html, body').stop().animate({
- 'scrollTop': $target.offset().top + 200
- }, 900, 'swing', function () {
- window.location.hash = target;
- });
- });
- /*search form*/
- $( '#search-form' ).find( 'input' ).keypress(function(e) {
- if(e.which == 13) {
- var cx = '004624818632696854117:yfmprrbw3pk&q=';
- 'find which search instance to use'
- if (DOCUMENTATION_OPTIONS.SEARCH_CX) {
- cx = DOCUMENTATION_OPTIONS.SEARCH_CX;
- }
- var searchterm = encodeURIComponent($(this).val());
- $(this).val("");
- window.location.href = 'https://www.google.com/cse?cx=' + cx + '&q=' + searchterm;
- }
- });
- /*menu collapse*/
- $( '#menu-toggle' ).click(function(e) {
- e.preventDefault();
- $( '#wrapper' ).toggleClass( 'toggled' );
- });
- /*version page selector*/
- $( 'div.releaselinks' ).on('click', 'a', function (e) {
- e.preventDefault();
- var clickedVer = $(this).attr("href");
- var $currentVer = $( 'div.versions' ).find( 'a.active' ).first();
- if (window.location.href.indexOf(clickedVer) == -1) {
- window.location.href = window.location.href.replace($currentVer.attr("href"), clickedVer);
- }
- else {
- if ($currentVer.text().indexOf("Master") == -1) {
- window.location.href = clickedVer + "topics/releases/" + $currentVer.text().trim() + ".html";
- }
- else window.location.href = clickedVer + "topics/releases/";
- }
- });
- /*lightbox around images*/
- $( 'img' ).not( '.nolightbox' ).each(function() {
- var source = $(this).attr( 'src' );
- var id = $(this).attr( 'id' );
- $(this).wrap('<a href="'+ source + '" data-lightbox="' + id + '"></a>' )
- });
- /*enable bootstrap tooltips*/
- $(function () {
- $('[data-toggle="tooltip"]').tooltip();
- });
- /*notification box*/
- var box;
- $("#notifications").on('click', function(e) {
- e.preventDefault();
- e.stopPropagation();
- $.get('//docs.saltstack.com/en/announcements.html?id=1', function (data) {
- box = bootbox.dialog({
- title: "Announcements",
- message: data
- });
- _gaq.push(['_trackEvent', 'docs', 'announcement-view']);
- });
- });
- $(document).on('click', '.bootbox', function (event) {
- box.modal('hide');
- });
- getMetaStatus();
- }); // $.document.ready
- //refresh on window resize
- var rtime = new Date(1, 1, 2000, 12,00,00);
- var timeout = false;
- var delta = 200;
- $(window).resize(function() {
- if (!$( '#menu-toggle' ).is(":visible")) {
- rtime = new Date();
- if (timeout === false) {
- timeout = true;
- setTimeout(resizeend, delta);
- }
- }
- });
- function resizeend() {
- if (new Date() - rtime < delta) {
- setTimeout(resizeend, delta);
- } else {
- timeout = false;
- if ($( window ).height() != windowheight && $(window).width() != windowwidth) {
- location.reload(false);
- }
- }
- }
- function last(list) {
- return list[list.length - 1];
- }
- var reviewTag = '<p><strong>Status: </strong><span class="label label-warning label-status" data-container="body" data-delay=\'{ "show": 100, "hide": 100 }\' data-toggle="tooltip" data-placement="right" title="This topic is being reviewed for technical accuracy">Technical Review</span></p>';
- var draftTag = '<p><strong>Status: </strong><span class="label label-important label-status" data-container="body" data-delay=\'{ "show": 100, "hide": 100 }\' data-toggle="tooltip" data-placement="right" title="This topic is a work in progress and might describe functionality that is not yet implemented. Use with caution.">Draft Content</span></p>';
- function getMetaStatus() {
- var metas = document.getElementsByTagName('meta');
- for (i=0; i<metas.length; i++) {
- if (metas[i].getAttribute("name") == "status") {
- var statusType = metas[i].getAttribute("content");
- (statusType == "review") ? tag = reviewTag : tag = draftTag;
- $( "h1" ).first().after(tag);
- }
- }
- }
- (function(document, history, location) {
- var HISTORY_SUPPORT = !!(history && history.pushState);
- var anchorScrolls = {
- ANCHOR_REGEX: /^#[^ ]+$/,
- OFFSET_HEIGHT_PX: 60,
- /**
- * Establish events, and fix initial scroll position if a hash is provided.
- */
- init: function() {
- this.scrollIfAnchor(location.hash);
- $('body').on('click', 'a', $.proxy(this, 'delegateAnchors'));
- },
- /**
- * Return the offset amount to deduct from the normal scroll position.
- * Modify as appropriate to allow for dynamic calculations
- */
- getFixedOffset: function() {
- return this.OFFSET_HEIGHT_PX;
- },
- /**
- * If the provided href is an anchor which resolves to an element on the
- * page, scroll to it.
- * @param {String} href
- * @return {Boolean} - Was the href an anchor.
- */
- scrollIfAnchor: function(href, pushToHistory) {
- var match, anchorOffset;
- if(!this.ANCHOR_REGEX.test(href)) {
- return false;
- }
- match = document.getElementById(href.slice(1));
- if(match) {
- anchorOffset = $(match).offset().top - this.getFixedOffset();
- $('html, body').animate({ scrollTop: anchorOffset});
- // Add the state to history as-per normal anchor links
- if(HISTORY_SUPPORT && pushToHistory) {
- history.pushState({}, document.title, location.pathname + href);
- }
- }
- return !!match;
- },
- /**
- * If the click event's target was an anchor, fix the scroll position.
- */
- delegateAnchors: function(e) {
- var elem = e.target;
- if(this.scrollIfAnchor(elem.getAttribute('href'), true)) {
- e.preventDefault();
- }
- }
- };
- $(document).ready($.proxy(anchorScrolls, 'init'));
- })(window.document, window.history, window.location);
|