finally fix blog issue

This commit is contained in:
Estevao Soares dos Santos 2018-10-17 02:33:10 +01:00
parent 413cedecf0
commit 66294bf67a
3 changed files with 50 additions and 85 deletions

View File

@ -23,16 +23,3 @@
</section>
</article>
</template>
<script>
(function () {
var canonical = $('#param-canonical').attr('value');
$.when(blogPosts.getPostByCanonical(canonical)).then(function(post) {
var article = Mustache.render($('#blog-article-tpl').html(), post);
$('#blog-post-container').html(article);
router.updatePageLinks();
$('pre code').each(function(i, block) {
hljs.highlightBlock(block);
});
});
})();
</script>

View File

@ -24,13 +24,14 @@
</article>
</template>
<script>
$.when(blogPosts.getList()).then(function(list) {
function loadBlogPosts(list) {
var articleWrapper = $('#articles-wrapper');
for (var i = 0; i < list.length; ++i) {
var article = Mustache.render($('#blog-list-article-tpl').html(), list[i]);
articleWrapper.prepend(article);
}
router.updatePageLinks();
});
}
$.when(blogPosts.getList()).then(loadBlogPosts);
</script>

View File

@ -15,39 +15,21 @@ $(document).ready(function() {
blogPosts = new BlogPosts();
function BlogPosts () {
var posts = [];
var indexedList = {};
var getList = this.getList = function() {
var dfd = jQuery.Deferred();
if (posts.length !== 0) {
dfd.resolve(posts);
} else {
$.getJSON('blog/posts.json', function(data) {
for (var i = 0; i < data.length; ++i) {
data[i].metadata.summary = converter.makeHtml(data[i].metadata.summary);
}
dfd.resolve(data);
});
}
return dfd.promise();
};
this.getPostByCanonical = function(canonical) {
var dfd = jQuery.Deferred();
var idx = null;
if (typeof indexedList[canonical] !== 'undefined') {
idx = indexedList[canonical];
}
$.when(getList()).then(function(list) {
if (idx !== null) {
dfd.resolve(list[idx]);
} else {
for (var i = 0; i < list.length; ++i) {
console.log(idx, list[i]);
if (list[i].canonical === canonical) {
var promise = $.ajax({
url: list[i].url,
@ -56,17 +38,12 @@ $(document).ready(function() {
promise.done((function (index, listItem) {
return function (md) {
listItem.post = converter.makeHtml(md);
posts[index] = listItem;
indexedList[canonical] = index;
dfd.resolve(listItem);
};
})(i, list[i]));
return;
}
}
dfd.resolve(null);
}
});
return dfd.promise();
};
@ -104,9 +81,22 @@ $(document).ready(function() {
return dfd.promise();
}
function loadPage(url) {
function loadPage(url, params) {
var $page = $('#page');
return $page.load(url, function () {
if (params && params.page === 'blog-article') {
$.when(blogPosts.getPostByCanonical(params.canonical)).then(function(post) {
var article = Mustache.render($('#blog-article-tpl').html(), post);
$('#blog-post-container').html(article);
$('pre code').each(function(i, block) {
hljs.highlightBlock(block);
hljs.lineNumbersBlock(block);
});
router.updatePageLinks();
});
}
$page.find('pre>code').each(function(i, block) {
hljs.highlightBlock(block);
hljs.lineNumbersBlock(block);
@ -115,19 +105,6 @@ $(document).ready(function() {
});
}
function injectParams(params) {
if (typeof params !== 'undefined') {
// pass params to page
for (var param in params) {
if (params.hasOwnProperty(param)) {
var $pageParams = $('#page-params');
$pageParams.html();
$pageParams.append('<data id="param-' + param + '" value="'+ params[param] +'" hidden style="display: none;"></data>');
}
}
}
}
function changeActiveLink(name) {
$('.internal-navigation').removeClass('active');
$('#navlink-' + name).addClass('active');
@ -141,26 +118,26 @@ $(document).ready(function() {
);
router
.on('/releases', function () {
.on('/releases', function (params) {
changeActiveLink('releases');
return loadPage('html/releases.html');
return loadPage('html/releases.html', params);
})
.on('/documentation', function () {
.on('/documentation', function (params) {
changeActiveLink('documentation');
return loadPage('html/documentation.html');
return loadPage('html/documentation.html', params);
})
.on('/blog/:canonical', function (params) {
params.page = 'blog-article';
changeActiveLink('blog');
injectParams(params);
return loadPage('html/blog-article.html', params);
})
.on('/blog', function () {
.on('/blog', function (params) {
changeActiveLink('blog');
return loadPage('html/blog.html');
return loadPage('html/blog.html', params);
})
.on('*', function () {
.on('*', function (params) {
changeActiveLink('home');
return loadPage('html/main.html');
return loadPage('html/main.html', params);
})
.resolve();