summaryrefslogtreecommitdiffstats
path: root/lib/utils/navigation.js
diff options
context:
space:
mode:
authorSamy Pessé <samypesse@gmail.com>2015-01-19 20:54:59 +0100
committerSamy Pessé <samypesse@gmail.com>2015-01-19 20:54:59 +0100
commitb549158483de1336b8b48a1ccbb5c87ea54e8b34 (patch)
treecd80478f807b30923bd7cf9008d3073ba7f070a8 /lib/utils/navigation.js
parent9a2b03b1835ca14239b61fb7b8610c782bb460e7 (diff)
downloadgitbook-b549158483de1336b8b48a1ccbb5c87ea54e8b34.zip
gitbook-b549158483de1336b8b48a1ccbb5c87ea54e8b34.tar.gz
gitbook-b549158483de1336b8b48a1ccbb5c87ea54e8b34.tar.bz2
Parse navigation and progress in parsed page
Diffstat (limited to 'lib/utils/navigation.js')
-rw-r--r--lib/utils/navigation.js64
1 files changed, 64 insertions, 0 deletions
diff --git a/lib/utils/navigation.js b/lib/utils/navigation.js
new file mode 100644
index 0000000..ae4eb9d
--- /dev/null
+++ b/lib/utils/navigation.js
@@ -0,0 +1,64 @@
+var _ = require('lodash');
+
+// Cleans up an article/chapter object
+// remove 'articles' attributes
+function clean(obj) {
+ return obj && _.omit(obj, ['articles']);
+}
+
+function flattenChapters(chapters) {
+ return _.reduce(chapters, function(accu, chapter) {
+ return accu.concat([clean(chapter)].concat(flattenChapters(chapter.articles)));
+ }, []);
+}
+
+// Returns from a summary a map of
+/*
+ {
+ "file/path.md": {
+ prev: ...,
+ next: ...,
+ },
+ ...
+ }
+*/
+function navigation(summary, files) {
+ // Support single files as well as list
+ files = _.isArray(files) ? files : (_.isString(files) ? [files] : null);
+
+ // List of all navNodes
+ // Flatten chapters, then add in default README node if ndeeded etc ...
+ var navNodes = flattenChapters(summary.chapters);
+ var prevNodes = [null].concat(navNodes.slice(0, -1));
+ var nextNodes = navNodes.slice(1).concat([null]);
+
+ // Mapping of prev/next for a give path
+ var mapping = _.chain(_.zip(navNodes, prevNodes, nextNodes))
+ .map(function(nodes) {
+ var current = nodes[0], prev = nodes[1], next = nodes[2];
+
+ // Skip if no path
+ if(!current.path) return null;
+
+ return [current.path, {
+ title: current.title,
+ prev: prev,
+ next: next,
+ level: current.level,
+ }];
+ })
+ .filter()
+ .object()
+ .value();
+
+ // Filter for only files we want
+ if(files) {
+ return _.pick(mapping, files);
+ }
+
+ return mapping;
+}
+
+
+// Exports
+module.exports = navigation;