$.browser.chrome = /chrome/.test(navigator.userAgent.toLowerCase()); $.browser.ipad = /ipad/.test(navigator.userAgent.toLowerCase()); /** * Initializes page contents for progressive enhancement. */ function initializeContents() { // hide all more buttons because they are not needed with JS $(".element a.more").hide(); $(".clickable.class,.clickable.interface").click(function() { document.location = $("a.more", this).attr('href'); }); // change the cursor to a pointer to make it more explicit that this it clickable // do a background color change on hover to emphasize the clickability eveb more // we do not use CSS for this because when JS is disabled this behaviour does not // apply and we do not want the hover $(".element.method,.element.function,.element.class.clickable,.element.interface.clickable,.element.property.clickable") .css("cursor", "pointer") .hover(function() { $(this).css('backgroundColor', '#F8FDF6') }, function(){ $(this).css('backgroundColor', 'white')} ); $("ul.side-nav.nav.nav-list li.nav-header").contents() .filter(function(){return this.nodeType == 3 && $.trim($(this).text()).length > 0}) .wrap(''); $("ul.side-nav.nav.nav-list li.nav-header span.side-nav-header") .css("cursor", "pointer"); // do not show tooltips on iPad; it will cause the user having to click twice if (!$.browser.ipad) { $('.btn-group.visibility,.btn-group.view,.btn-group.type-filter,.icon-custom') .tooltip({'placement':'bottom'}); $('.element').tooltip({'placement':'left'}); } $('.btn-group.visibility,.btn-group.view,.btn-group.type-filter') .show() .css('display', 'inline-block') .find('button') .find('i').click(function(){ $(this).parent().click(); }); // set the events for the visibility buttons and enable by default. $('.visibility button.public').click(function(){ $('.element.public,.side-nav li.public').toggle($(this).hasClass('active')); }).click(); $('.visibility button.protected').click(function(){ $('.element.protected,.side-nav li.protected').toggle($(this).hasClass('active')); }).click(); $('.visibility button.private').click(function(){ $('.element.private,.side-nav li.private').toggle($(this).hasClass('active')); }).click(); $('.visibility button.inherited').click(function(){ $('.element.inherited,.side-nav li.inherited').toggle($(this).hasClass('active')); }).click(); $('.type-filter button.critical').click(function(){ $('tr.critical').toggle($(this).hasClass('active')); }); $('.type-filter button.error').click(function(){ $('tr.error').toggle($(this).hasClass('active')); }); $('.type-filter button.notice').click(function(){ $('tr.notice').toggle($(this).hasClass('active')); }); $('.view button.details').click(function(){ $('.side-nav li.view-simple').removeClass('view-simple'); }).button('toggle').click(); $('.view button.simple').click(function(){ $('.side-nav li').addClass('view-simple'); }); $('ul.side-nav.nav.nav-list li.nav-header span.side-nav-header').click(function(){ $(this).siblings('ul').collapse('toggle'); }); // sorting example // $('ol li').sort( // function(a, b) { return a.innerHTML.toLowerCase() > b.innerHTML.toLowerCase() ? 1 : -1; } // ).appendTo('ol'); } $(document).ready(function() { prettyPrint(); initializeContents(); // do not show tooltips on iPad; it will cause the user having to click twice if(!$.browser.ipad) { $(".side-nav a").tooltip({'placement': 'top'}); } // chrome cannot deal with certain situations; warn the user about reduced features if ($.browser.chrome && (window.location.protocol == 'file:')) { $("body > .container").prepend( '