summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorsmain@google.com <smain@google.com>2014-06-16 19:24:25 -0700
committersmain@google.com <smain@google.com>2014-06-16 19:25:14 -0700
commit95948b88ec17e5b0f5b9cdcc43b08989cec2a34a (patch)
treead7baf819b1712188820aecb3bac38b782cc7f9d
parent908a05a1ee87bdf6d4f27355d0a0d648ab8f8da0 (diff)
downloadbuild-95948b88ec17e5b0f5b9cdcc43b08989cec2a34a.zip
build-95948b88ec17e5b0f5b9cdcc43b08989cec2a34a.tar.gz
build-95948b88ec17e5b0f5b9cdcc43b08989cec2a34a.tar.bz2
add script and style for toggling which IDE instructions to show.
Change-Id: Ief094a4f58c7ebb4625948d6639fed713adcc0c7
-rw-r--r--tools/droiddoc/templates-sdk/assets/css/default.css28
-rw-r--r--tools/droiddoc/templates-sdk/assets/js/docs.js146
-rw-r--r--tools/droiddoc/templates-sdk/sdkpage.cs2
3 files changed, 106 insertions, 70 deletions
diff --git a/tools/droiddoc/templates-sdk/assets/css/default.css b/tools/droiddoc/templates-sdk/assets/css/default.css
index 8a76c54..1c45596 100644
--- a/tools/droiddoc/templates-sdk/assets/css/default.css
+++ b/tools/droiddoc/templates-sdk/assets/css/default.css
@@ -2989,6 +2989,34 @@ a.header-toggle {
}
+/* for IDE instruction toggle (Studio/Eclipse/Other) */
+select.ide {
+ background: transparent;
+ border: 1px solid #bbb;
+ border-left: 0;
+ border-right: 0;
+ margin: 10px 0;
+ padding: 10px 0;
+ color:#666;
+}
+select.ide,
+select.ide option {
+ font-family: inherit;
+ font-size:16px;
+ font-weight:500;
+}
+/* hide all except eclipse by default */
+.select-ide.studio,
+.select-ide.other {
+ display:none;
+}
+/* ... unless eclipse also includes one of the others */
+.select-ide.eclipse.studio,
+.select-ide.eclipse.other {
+ display:block;
+}
+
+
/* -----------------------------------------------
good/bad example containers
*/
diff --git a/tools/droiddoc/templates-sdk/assets/js/docs.js b/tools/droiddoc/templates-sdk/assets/js/docs.js
index c10b848..fb9f5b2 100644
--- a/tools/droiddoc/templates-sdk/assets/js/docs.js
+++ b/tools/droiddoc/templates-sdk/assets/js/docs.js
@@ -1088,8 +1088,16 @@ function hideNestedItems(list, toggle) {
}
-
-
+/* Call this to add listeners to a <select> element for Studio/Eclipse/Other docs */
+function setupIdeDocToggle() {
+ $( "select.ide" ).change(function() {
+ var selected = $(this).find("option:selected").attr("value");
+ $(".select-ide").hide();
+ $(".select-ide."+selected).show();
+
+ $("select.ide").val(selected);
+ });
+}
@@ -3444,8 +3452,8 @@ function showSamples() {
} else if (isCarousel) {
drawResourcesCarouselWidget($widget, opts, resources);
} else if (isStack) {
- /* Looks like this got removed and is not used, so repurposing for the
- homepage style layout.
+ /* Looks like this got removed and is not used, so repurposing for the
+ homepage style layout.
Modified by LFL 6/6/14
*/
//var sections = buildSectionList(opts);
@@ -3534,11 +3542,11 @@ function showSamples() {
for (var i = 0; i < resources.length; ++i) {
var $card = createResourceElement(resources[i], opts);
-
+
if (opts.resourceStyle.indexOf('related') > -1) {
$card.addClass('related-card');
}
-
+
cards.push($card[0]);
}
@@ -3562,14 +3570,14 @@ function showSamples() {
}
};
-
- /*
+
+ /*
Create a resource card using the given resource object and a list of html
configured options. Returns a jquery object containing the element.
*/
- function createResourceElement(resource, opts, plusone) {
+ function createResourceElement(resource, opts, plusone) {
var $el;
-
+
// The difference here is that generic cards are not entirely clickable
// so its a div instead of an a tag, also the generic one is not given
// the resource-card class so it appears with a transparent background
@@ -3581,13 +3589,13 @@ function showSamples() {
.decorateResource(resource, opts);
} else {
var cls = 'resource resource-card';
-
+
$el = $('<a>')
.addClass(cls)
.attr('href', cleanUrl(resource.url))
.decorateResourceCard(resource, plusone);
}
-
+
return $el;
}
@@ -3624,10 +3632,10 @@ function showSamples() {
var resource = resources[i];
var $card = createResourceElement(resources[i], opts, plusone);
-
- $card.addClass('resource-card-' + cardSize +
+
+ $card.addClass('resource-card-' + cardSize +
' resource-card-' + resource.type);
-
+
if (isStack) {
$card.addClass('resource-card-' + isStack[1] + 'x' + isStack[2]);
if (++stackCount == parseInt(isStack[3])) {
@@ -3777,13 +3785,13 @@ function showSamples() {
}
return true;
}
-
+
function cleanUrl(url)
{
if (url && url.indexOf('//') === -1) {
url = toRoot + url;
}
-
+
return url;
}
@@ -3835,49 +3843,49 @@ function showSamples() {
(function($) {
- /*
+ /*
Utility method for creating dom for the description area of a card.
Used in decorateResourceCard and decorateResource.
*/
function buildResourceCardDescription(resource, plusone) {
var $description = $('<div>').addClass('description ellipsis');
-
+
$description.append($('<div>').addClass('text').html(resource.summary));
-
+
if (resource.cta) {
$description.append($('<a>').addClass('cta').html(resource.cta));
}
-
+
if (plusone) {
- var plusurl = resource.url.indexOf("//") > -1 ? resource.url :
+ var plusurl = resource.url.indexOf("//") > -1 ? resource.url :
"//developer.android.com/" + resource.url;
-
+
$description.append($('<div>').addClass('util')
.append($('<div>').addClass('g-plusone')
.attr('data-size', 'small')
.attr('data-align', 'right')
.attr('data-href', plusurl)));
}
-
+
return $description;
}
-
-
+
+
/* Simple jquery function to create dom for a standard resource card */
$.fn.decorateResourceCard = function(resource,plusone) {
var section = resource.group || resource.type;
- var imgUrl = resource.image ||
+ var imgUrl = resource.image ||
'assets/images/resource-card-default-android.jpg';
-
+
if (imgUrl.indexOf('//') === -1) {
imgUrl = toRoot + imgUrl;
}
$('<div>').addClass('card-bg')
- .css('background-image', 'url(' + (imgUrl || toRoot +
+ .css('background-image', 'url(' + (imgUrl || toRoot +
'assets/images/resource-card-default-android.jpg') + ')')
.appendTo(this);
-
+
$('<div>').addClass('card-info' + (!resource.summary ? ' empty-desc' : ''))
.append($('<div>').addClass('section').text(section))
.append($('<div>').addClass('title').html(resource.title))
@@ -3965,20 +3973,20 @@ function showSamples() {
return this;
};
-
-
-
-
+
+
+
+
/* Render other types of resource styles that are not cards. */
$.fn.decorateResource = function(resource, opts) {
- var imgUrl = resource.image ||
+ var imgUrl = resource.image ||
'assets/images/resource-card-default-android.jpg';
var linkUrl = resource.url;
-
+
if (imgUrl.indexOf('//') === -1) {
imgUrl = toRoot + imgUrl;
}
-
+
if (linkUrl && linkUrl.indexOf('//') === -1) {
linkUrl = toRoot + linkUrl;
}
@@ -4022,13 +4030,13 @@ function showSamples() {
/*
Fullscreen Carousel
-
+
The following allows for an area at the top of the page that takes over the
- entire browser height except for its top offset and an optional bottom
+ entire browser height except for its top offset and an optional bottom
padding specified as a data attribute.
-
+
HTML:
-
+
<div class="fullscreen-carousel">
<div class="fullscreen-carousel-content">
<!-- content here -->
@@ -4036,18 +4044,18 @@ function showSamples() {
<div class="fullscreen-carousel-content">
<!-- content here -->
</div>
-
+
etc ...
-
+
</div>
-
+
Control over how the carousel takes over the screen can mostly be defined in
a css file. Setting min-height on the .fullscreen-carousel-content elements
- will prevent them from shrinking to far vertically when the browser is very
+ will prevent them from shrinking to far vertically when the browser is very
short, and setting max-height on the .fullscreen-carousel itself will prevent
- the area from becoming to long in the case that the browser is stretched very
+ the area from becoming to long in the case that the browser is stretched very
tall.
-
+
There is limited functionality for having multiple sections since that request
was removed, but it is possible to add .next-arrow and .prev-arrow elements to
scroll between multiple content areas.
@@ -4062,7 +4070,7 @@ function showSamples() {
function initWidget(widget) {
var $widget = $(widget);
-
+
var topOffset = $widget.offset().top;
var padBottom = parseInt($widget.data('paddingbottom')) || 0;
var maxHeight = 0;
@@ -4071,7 +4079,7 @@ function showSamples() {
var $nextArrow = $widget.find('.next-arrow');
var $prevArrow = $widget.find('.prev-arrow');
var $curSection = $($content[0]);
-
+
if ($content.length <= 1) {
$nextArrow.hide();
$prevArrow.hide();
@@ -4082,7 +4090,7 @@ function showSamples() {
$curSection = $($content[index >= $content.length ? 0 : index]);
$curSection.show();
});
-
+
$prevArrow.click(function() {
var index = ($content.index($curSection) - 1);
$curSection.hide();
@@ -4104,10 +4112,10 @@ function showSamples() {
function resizeWidget() {
var height = $(window).height() - topOffset - padBottom;
$widget.width($(window).width());
- $widget.height(height < minHeight ? minHeight :
+ $widget.height(height < minHeight ? minHeight :
(maxHeight && height > maxHeight ? maxHeight : height));
}
- }
+ }
})();
@@ -4116,36 +4124,36 @@ function showSamples() {
/*
Tab Carousel
-
+
The following allows tab widgets to be installed via the html below. Each
tab content section should have a data-tab attribute matching one of the
nav items'. Also each tab content section should have a width matching the
tab carousel.
-
+
HTML:
-
+
<div class="tab-carousel">
<ul class="tab-nav">
<li><a href="#" data-tab="handsets">Handsets</a>
<li><a href="#" data-tab="wearable">Wearable</a>
<li><a href="#" data-tab="tv">TV</a>
</ul>
-
+
<div class="tab-carousel-content">
<div data-tab="handsets">
<!--Full width content here-->
</div>
-
+
<div data-tab="wearable">
<!--Full width content here-->
</div>
-
+
<div data-tab="tv">
<!--Full width content here-->
</div>
</div>
</div>
-
+
*/
(function() {
$(document).ready(function() {
@@ -4168,40 +4176,40 @@ function showSamples() {
$anchors.click(function(evt) {
evt.preventDefault();
var query = '[data-tab=' + $(this).data('tab') + ']';
- transitionWidget($tabs.filter(query));
+ transitionWidget($tabs.filter(query));
});
-
+
// Add highlight for navigation on first item.
var $highlight = $('<div>').addClass('highlight')
.css({left:$li.position().left + 'px', width:$li.outerWidth() + 'px'})
.appendTo($nav);
-
+
// Store height since we will change contents to absolute.
$contentContainer.height($contentContainer.height());
-
+
// Absolutely position tabs so they're ready for transition.
$tabs.each(function(index) {
$(this).css({position: 'absolute', left: index > 0 ? width + 'px' : '0'});
});
-
+
function transitionWidget($toTab) {
if (!$curTab.is($toTab)) {
var curIndex = $tabs.index($curTab[0]);
var toIndex = $tabs.index($toTab[0]);
var dir = toIndex > curIndex ? 1 : -1;
-
+
// Animate content sections.
$toTab.css({left:(width * dir) + 'px'});
$curTab.animate({left:(width * -dir) + 'px'});
$toTab.animate({left:'0'});
-
+
// Animate navigation highlight.
- $highlight.animate({left:$($li[toIndex]).position().left + 'px',
+ $highlight.animate({left:$($li[toIndex]).position().left + 'px',
width:$($li[toIndex]).outerWidth() + 'px'})
-
+
// Store new current section.
$curTab = $toTab;
}
}
- }
+ }
})(); \ No newline at end of file
diff --git a/tools/droiddoc/templates-sdk/sdkpage.cs b/tools/droiddoc/templates-sdk/sdkpage.cs
index 140cf8f..7652faf 100644
--- a/tools/droiddoc/templates-sdk/sdkpage.cs
+++ b/tools/droiddoc/templates-sdk/sdkpage.cs
@@ -501,7 +501,7 @@ var:sdk.linux_download
function onDownloadForRealz(link) {
if ($("input#agree").is(':checked') && $("#bitpicker input:checked").length) {
$("div.sdk-terms").slideUp();
- $("h1#tos-header").text('Now downloading ' + $(link).text() + '...');
+ $("h1#tos-header").text('Now redirecting to the install instructions...');
$("#sdk-terms-form,.sdk-terms-intro").fadeOut('slow', function() {
setTimeout(function() {
if ($("#downloadForRealz").attr('bundle') == 'true') {