mirror of
https://github.com/jerryc127/hexo-theme-butterfly.git
synced 2025-09-15 12:58:48 +08:00
1. 可設置隱藏文章 2. 適配 Hexo 的 Tag Plugins Code Block With marked lines 顯示 3. 可配置首頁cover顯示的位置 4. 更改深色模式下的配色 5. activate_power_mode 增加關閉顏色和抖動 6. 增加谷歌廣告,騰訊分析 7. 相關文章增加時間顯示,調整佈局,垂直居中 8. 文章頁面,top_img增加評論數顯示 9. 可以取消點擊圖片觀看大圖 10. mathjax和kathex可設置每頁都加載還是按需加載 11. 深色模式下,滾動條顔色的適配 12. 優化gitalk 在 dark mode下的顯示 13. 文章頁,文章標題過長時,只顯示三行內容 14. 深色模式下,背景圖片加上蒙板 15. 優化深色/閲讀模式下,canvas的顯示 16. 優化打賞的特效和移動到二維碼不會立刻消失 17. 優化sub-menu樣式 18. 修改aside 的tags顔色,在深色模式下不會出現觀看困難 19. 升級 normalize.css 到最新版 20. 優化手機上toc和menu的打開動畫 21. 優化代碼框打開關閉的特效 22. 精簡js,部分操作改為css控制 23. 優化主題的一些動畫,不會過於生硬 1. 修復當圖片被a標簽包圍時,點擊圖標沒有跳轉到對應網頁而是出現大圖觀看模式的bug 2. 修復當網址有subdirectory時,menu、打賞二維碼和lodding_bg 鏈接路徑錯誤的bug 3. 修復當網址有subdirectory時, 4. 修復katex 的 CSS無法讀取bug 5. 修復搜索按鈕在文章頁不顯示的bug 6. 修復gitalk css引用失敗的bug 7. 修復 點擊特效 煙花 無效的bug 8. 修復gitalk報path.startsWith is not a function的bug 9. 修復 閲讀模式下,背景沒有變純色的bug 10. 修復閲讀模式下,header 偶爾出現沒有靠攏頂部的bug 11. 修復Hexo Tag Plugins Block Quote 裏的鏈接顯示出外面的Bug 12. 修復aside歸檔日期過長導致錯位的bug 13. 修復toc為空時,toc按鈕仍存在的bug 14. 修復關閉懶加載後,頭像無法顯示的bug 15. 修復深色模式下,切換readmode偶爾會無效的bug 16. 修復在一些手機設備上,toc和menu的按鈕顯示不對齊的bug #72
121 lines
3.7 KiB
JavaScript
121 lines
3.7 KiB
JavaScript
const moment = require('moment-timezone');
|
|
const {
|
|
isMoment
|
|
} = moment;
|
|
|
|
|
|
|
|
hexo.extend.helper.register('related_posts', function (currentPost, allPosts) {
|
|
var relatedPosts = [];
|
|
currentPost.tags.forEach(function (tag) {
|
|
allPosts.forEach(function (post) {
|
|
if (isTagRelated(tag.name, post.tags)) {
|
|
var relatedPost = {
|
|
title: post.title,
|
|
path: post.path,
|
|
cover: post.cover,
|
|
weight: 1,
|
|
updated: post.updated,
|
|
created: post.created
|
|
};
|
|
var index = findItem(relatedPosts, 'path', post.path);
|
|
if (index != -1) {
|
|
relatedPosts[index].weight += 1;
|
|
} else {
|
|
if (currentPost.path != post.path) {
|
|
relatedPosts.push(relatedPost);
|
|
};
|
|
};
|
|
};
|
|
});
|
|
});
|
|
if (relatedPosts.length == 0) {
|
|
return ''
|
|
};
|
|
var result = "";
|
|
const hexoConfig = hexo.theme.config.rootConfig;
|
|
const config = hexo.theme.config;
|
|
|
|
var limit_num = config.related_post.limit || 6
|
|
var lang = hexoConfig.language;
|
|
var date_type = config.related_post.date_type || 'created'
|
|
var headline_lang;
|
|
if (lang === 'zh-CN') {
|
|
headline_lang = '相关推荐';
|
|
} else if (lang === 'zh-TW') {
|
|
headline_lang = '相關推薦';
|
|
} else {
|
|
headline_lang = 'Recommend';
|
|
}
|
|
|
|
relatedPosts = relatedPosts.sort(compare('weight'));
|
|
var lazy_src = config.lazyload.enable ? lazy_src = 'data-src' : lazy_src = 'src'
|
|
var lazy_class = config.lazyload.enable ? lazy_class = 'lazyload' : lazy_class = ''
|
|
|
|
if (relatedPosts.length > 0) {
|
|
result += '<div class="relatedPosts">'
|
|
result += '<div class="relatedPosts_headline"><i class="fa fa-fw fa-thumbs-up" aria-hidden="true"></i><span>' + ' ' + headline_lang + '</span></div>'
|
|
result += '<div class="relatedPosts_list">'
|
|
|
|
for (var i = 0; i < Math.min(relatedPosts.length, limit_num); i++) {
|
|
|
|
var cover = relatedPosts[i].cover
|
|
|
|
result += '<div class="relatedPosts_item"><a href="' + hexoConfig.root + relatedPosts[i].path + '" title="' + relatedPosts[i].title + '">';
|
|
result += '<img class="relatedPosts_cover ' + lazy_class + '"' + lazy_src + '="' + cover + '">';
|
|
if (date_type == 'created') {
|
|
result += '<div class="relatedPosts_main is-center"><div class="relatedPosts_date"><i class="fa fa-calendar fa-fw" aria-hidden="true"></i>' + ' ' + dateHelper(relatedPosts[i].created) + '</div>'
|
|
} else {
|
|
result += '<div class="relatedPosts_main"><div class="relatedPosts_date"><i class="fa fa-history fa-fw" aria-hidden="true"></i>' + ' ' + dateHelper(relatedPosts[i].updated) + '</div>'
|
|
}
|
|
result += '<div class="relatedPosts_title">' + relatedPosts[i].title + '</div>';
|
|
result += '</div></a></div>'
|
|
};
|
|
|
|
result += '</div><div class="clear_both"></div></div>'
|
|
return result;
|
|
|
|
}
|
|
});
|
|
hexo.extend.helper.register('echo', function (path) {
|
|
return path;
|
|
});
|
|
|
|
function isTagRelated(tagName, TBDtags) {
|
|
var result = false;
|
|
TBDtags.forEach(function (tag) {
|
|
if (tagName == tag.name) {
|
|
result = true;
|
|
};
|
|
})
|
|
return result;
|
|
}
|
|
|
|
function findItem(arrayToSearch, attr, val) {
|
|
for (var i = 0; i < arrayToSearch.length; i++) {
|
|
if (arrayToSearch[i][attr] == val) {
|
|
return i
|
|
};
|
|
};
|
|
return -1;
|
|
}
|
|
|
|
function compare(attr) {
|
|
return function (a, b) {
|
|
var val1 = a[attr];
|
|
var val2 = b[attr];
|
|
return val2 - val1;
|
|
}
|
|
}
|
|
|
|
function dateHelper(date) {
|
|
const moment = getMoment(date, hexo.theme.config.rootConfig.language);
|
|
return moment.format(hexo.theme.config.rootConfig.date_format);
|
|
}
|
|
|
|
function getMoment(date, lang) {
|
|
if (date == null) date = moment();
|
|
if (!isMoment(date)) date = moment(isDate(date) ? date : new Date(date));
|
|
if (lang) date = date.locale(lang);
|
|
return date;
|
|
} |