// NOTICE!! DO NOT USE ANY OF THIS JAVASCRIPT // IT'S ALL JUST JUNK FOR OUR DOCS! // ++++++++++++++++++++++++++++++++++++++++++ /*! * JavaScript for Bootstrap's docs (http://getbootstrap.com) * Copyright 2011-2014 Twitter, Inc. * Licensed under the Creative Commons Attribution 3.0 Unported License. For * details, see http://creativecommons.org/licenses/by/3.0/. */ !function ($) { 'use strict'; $(function () { // Scrollspy var $window = $(window) var $body = $(document.body) $body.scrollspy({ target: '.bs-docs-sidebar' }) $window.on('load', function () { $body.scrollspy('refresh') }) // Kill links $('.bs-docs-container [href=#]').click(function (e) { e.preventDefault() }) // Sidenav affixing setTimeout(function () { var $sideBar = $('.bs-docs-sidebar') $sideBar.affix({ offset: { top: function () { var offsetTop = $sideBar.offset().top var sideBarMargin = parseInt($sideBar.children(0).css('margin-top'), 10) var navOuterHeight = $('.bs-docs-nav').height() return (this.top = offsetTop - navOuterHeight - sideBarMargin) }, bottom: function () { return (this.bottom = $('.bs-docs-footer').outerHeight(true)) } } }) }, 100) setTimeout(function () { $('.bs-top').affix() }, 100) // theme toggler ;(function () { var stylesheetLink = $('#bs-theme-stylesheet') var themeBtn = $('.bs-docs-theme-toggle') themeBtn.click(function () { var href = stylesheetLink.attr('href'); if (!href || href.indexOf('data') === 0) { stylesheetLink.attr('href', stylesheetLink.attr('data-href')) themeBtn.text('Disable theme preview') } else { stylesheetLink.attr('href', '') themeBtn.text('Preview theme') } }) })(); // Tooltip and popover demos $('.tooltip-demo').tooltip({ selector: '[data-toggle="tooltip"]', container: 'body' }) $('.tooltip-test').tooltip() $('.popover-test').popover() $('.bs-docs-navbar').tooltip({ selector: 'a[data-toggle="tooltip"]', container: '.bs-docs-navbar .nav' }) // Default popover demo $('.bs-docs-popover').popover() // Button state demo $('#loading-example-btn').click(function () { var btn = $(this) btn.button('loading') setTimeout(function () { btn.button('reset') }, 3000) }) // Config ZeroClipboard ZeroClipboard.config({ moviePath: '/assets/flash/zero-clipboard.swf', hoverClass: 'btn-clipboard-hover' }) // Insert copy to clipboard button before .highlight or .bs-example $('.highlight').each(function() { var highlight = $(this) var previous = highlight.prev() var btnHtml = '
Copy
' if (previous.hasClass('bs-example')) { previous.before(btnHtml.replace(/btn-clipboard/, 'btn-clipboard with-example')) } else { highlight.before(btnHtml) } }) var zeroClipboard = new ZeroClipboard($('.btn-clipboard')) var htmlBridge = $('#global-zeroclipboard-html-bridge') // Handlers for ZeroClipboard zeroClipboard.on('load', function(client) { htmlBridge .data('placement', 'top') .attr('title', 'Copy to clipboard') .tooltip() }) // Copy to clipboard zeroClipboard.on('dataRequested', function(client) { var highlight = $(this).parent().nextAll('.highlight').first() client.setText(highlight.text()) }) // Notify copy success and reset tooltip title zeroClipboard.on('complete', function(client) { htmlBridge .attr('title', 'Copied!') .tooltip('fixTitle') .tooltip('show') .attr('title', 'Copy') .tooltip('fixTitle') }) // Notify copy failure zeroClipboard.on('noflash wrongflash', function(client) { htmlBridge .attr('title', 'Flash required') .tooltip('fixTitle') .tooltip('show') }) }) }(jQuery)