diff options
author | Samy Pessé <samypesse@gmail.com> | 2016-04-28 14:12:21 +0200 |
---|---|---|
committer | Samy Pessé <samypesse@gmail.com> | 2016-04-28 14:12:21 +0200 |
commit | 5059e8df3466bf33c379f3ed0626f48904e9cbcc (patch) | |
tree | f39b0e7254ab66e942af27cda3fc5e6f9fd631ab /lib/modifiers/summary/insertArticle.js | |
parent | 3d405a1ac56e6c0e63276e0918ab8bd8fae82142 (diff) | |
download | gitbook-5059e8df3466bf33c379f3ed0626f48904e9cbcc.zip gitbook-5059e8df3466bf33c379f3ed0626f48904e9cbcc.tar.gz gitbook-5059e8df3466bf33c379f3ed0626f48904e9cbcc.tar.bz2 |
Add modifiers to edit article and insert in summary
Diffstat (limited to 'lib/modifiers/summary/insertArticle.js')
-rw-r--r-- | lib/modifiers/summary/insertArticle.js | 50 |
1 files changed, 48 insertions, 2 deletions
diff --git a/lib/modifiers/summary/insertArticle.js b/lib/modifiers/summary/insertArticle.js index ec29978..ae920c2 100644 --- a/lib/modifiers/summary/insertArticle.js +++ b/lib/modifiers/summary/insertArticle.js @@ -1,16 +1,62 @@ +var is = require('is'); var SummaryArticle = require('../../models/summaryArticle'); +var editArticle = require('./editArticle'); +var indexArticleLevels = require('./indexArticleLevels'); + + +/** + Get level of parent of an article + + @param {String} level + @return {String} +*/ +function getParentLevel(level) { + var parts = level.split('.'); + return parts.slice(0, -1).join('.'); +} /** - Insert an article in a summary, and reindex levels correctly + Insert an article in a summary at a specific position @param {Summary} summary - @param {String} level: level to insert after + @param {String|Article} level: level to insert after @param {Article} article @return {Summary} */ function insertArticle(summary, level, article) { article = SummaryArticle(article); + level = is.string(level)? level : level.getLevel(); + + var parentLevel = getParentLevel(level); + + if (!parentLevel) { + // todo: insert new part + return summary; + } + + // Get parent of the position + var parentArticle = summary.getByLevel(parentLevel); + if (!parentLevel) { + return summary; + } + + // Find the index to insert at + var articles = parentArticle.getArticles(); + var index = articles.findIndex(function(art) { + return art.getLevel() === level; + }); + if (!index) { + return summary; + } + + // Insert the article at the right index + articles = articles.insert(index, article); + + // Reindex the level from here + parentArticle = parentArticle.set('articles', articles); + parentArticle = indexArticleLevels(parentArticle); + return editArticle(summary, parentLevel, parentArticle); } |