mirror of
https://github.com/status-im/react-native.git
synced 2025-01-23 07:49:25 +00:00
00c77800c9
Summary: Fixes #7519 JS detects handheld device by sniffing UA string (very primitive detection). If on handheld device, event listener is registered. Event handler toggles Docs Navigation overlay after clicking on "Docs" nav button. Original Docs Navigation panel is taken out of the natural page flow using pure CSS and is styled to look "good" on device. As a result of this, Navigation overlay is ONLY visible when you are at Docs page, otherwise "Docs" nav button takes you Docs page first. iPhone/iPad previews ![iphone](https://cloud.githubusercontent.com/assets/829963/15409630/f1a64b1a-1e15-11e6-92eb-f85c5cd06754.gif) ![ipad](https://cloud.githubusercontent.com/assets/829963/15409631/f1a6f952-1e15-11e6-8f5c-6f89f54e6814.gif) Closes https://github.com/facebook/react-native/pull/7640 Differential Revision: D3325440 Pulled By: vjeux fbshipit-source-id: a06b21d743d56bfea5db5b750836856c3af9bbe2
102 lines
2.9 KiB
JavaScript
102 lines
2.9 KiB
JavaScript
/**
|
|
* Copyright (c) 2015-present, Facebook, Inc.
|
|
* All rights reserved.
|
|
*
|
|
* This source code is licensed under the BSD-style license found in the
|
|
* LICENSE file in the root directory of this source tree. An additional grant
|
|
* of patent rights can be found in the PATENTS file in the same directory.
|
|
*
|
|
* @providesModule DocsSidebar
|
|
*/
|
|
|
|
var React = require('React');
|
|
var Metadata = require('Metadata');
|
|
|
|
var DocsSidebar = React.createClass({
|
|
getCategories: function() {
|
|
var metadatas = Metadata.files.filter(function(metadata) {
|
|
return metadata.layout === 'docs' || metadata.layout === 'autodocs';
|
|
});
|
|
|
|
// Build a hashmap of article_id -> metadata
|
|
var articles = {};
|
|
for (var i = 0; i < metadatas.length; ++i) {
|
|
var metadata = metadatas[i];
|
|
articles[metadata.id] = metadata;
|
|
}
|
|
|
|
// Build a hashmap of article_id -> previous_id
|
|
var previous = {};
|
|
for (var i = 0; i < metadatas.length; ++i) {
|
|
var metadata = metadatas[i];
|
|
if (metadata.next) {
|
|
if (!articles[metadata.next]) {
|
|
throw '`next: ' + metadata.next + '` in ' + metadata.id + ' doesn\'t exist';
|
|
}
|
|
previous[articles[metadata.next].id] = metadata.id;
|
|
}
|
|
}
|
|
|
|
// Find the first element which doesn't have any previous
|
|
var first = null;
|
|
for (var i = 0; i < metadatas.length; ++i) {
|
|
var metadata = metadatas[i];
|
|
if (!previous[metadata.id]) {
|
|
first = metadata;
|
|
break;
|
|
}
|
|
}
|
|
|
|
var categories = [];
|
|
var currentCategory = null;
|
|
|
|
var metadata = first;
|
|
var i = 0;
|
|
while (metadata && i++ < 1000) {
|
|
if (!currentCategory || metadata.category !== currentCategory.name) {
|
|
currentCategory && categories.push(currentCategory);
|
|
currentCategory = {
|
|
name: metadata.category,
|
|
links: []
|
|
};
|
|
}
|
|
currentCategory.links.push(metadata);
|
|
metadata = articles[metadata.next];
|
|
}
|
|
categories.push(currentCategory);
|
|
|
|
return categories;
|
|
},
|
|
|
|
getLink: function(metadata) {
|
|
return metadata.permalink;
|
|
},
|
|
|
|
render: function() {
|
|
return <div className="nav-docs">
|
|
<div className="nav-docs-viewport">
|
|
{this.getCategories().map((category) =>
|
|
<div className="nav-docs-section" key={category.name}>
|
|
<h3>{category.name}</h3>
|
|
<ul>
|
|
{category.links.map((metadata) =>
|
|
<li key={metadata.id}>
|
|
<a
|
|
target={metadata.permalink.match(/^https?:/) && '_blank'}
|
|
style={{marginLeft: metadata.indent ? 20 : 0}}
|
|
className={metadata.id === this.props.metadata.id ? 'active' : ''}
|
|
href={this.getLink(metadata)}>
|
|
{metadata.title}
|
|
</a>
|
|
</li>
|
|
)}
|
|
</ul>
|
|
</div>
|
|
)}
|
|
</div>
|
|
</div>;
|
|
}
|
|
});
|
|
|
|
module.exports = DocsSidebar;
|