mirror of
https://github.com/jerryc127/hexo-theme-butterfly.git
synced 2026-04-16 19:00:53 +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
104 lines
2.5 KiB
JavaScript
104 lines
2.5 KiB
JavaScript
"use strict";
|
|
|
|
hexo.extend.helper.register("list_archives", function(options = {}) {
|
|
const { config } = this;
|
|
const archiveDir = config.archive_dir;
|
|
const { timezone } = config;
|
|
const lang = this.page.lang || this.page.language || config.language;
|
|
let { format } = options;
|
|
const type = options.type || "monthly";
|
|
const { style = "list", transform, separator = ", " } = options;
|
|
const showCount = Object.prototype.hasOwnProperty.call(options, "show_count")
|
|
? options.show_count
|
|
: true;
|
|
const order = options.order || -1;
|
|
const limit = 8;
|
|
let result = "";
|
|
|
|
var more_button;
|
|
if (lang === "zh-CN") {
|
|
more_button = "查看更多";
|
|
} else if (lang === "zh-TW") {
|
|
more_button = "查看更多";
|
|
} else {
|
|
more_button = "More";
|
|
}
|
|
|
|
if (!format) {
|
|
format = type === "monthly" ? "MMMM YYYY" : "YYYY";
|
|
}
|
|
|
|
const posts = this.site.posts.sort("date", order);
|
|
if (!posts.length) return result;
|
|
|
|
const data = [];
|
|
let length = 0;
|
|
|
|
posts.forEach(post => {
|
|
// Clone the date object to avoid pollution
|
|
let date = post.date.clone();
|
|
|
|
if (timezone) date = date.tz(timezone);
|
|
if (lang) date = date.locale(lang);
|
|
|
|
const year = date.year();
|
|
const month = date.month() + 1;
|
|
const name = date.format(format);
|
|
const lastData = data[length - 1];
|
|
|
|
if (!lastData || lastData.name !== name) {
|
|
length = data.push({
|
|
name,
|
|
year,
|
|
month,
|
|
count: 1
|
|
});
|
|
} else {
|
|
lastData.count++;
|
|
}
|
|
});
|
|
|
|
const link = item => {
|
|
let url = `${archiveDir}/${item.year}/`;
|
|
|
|
if (type === "monthly") {
|
|
if (item.month < 10) url += "0";
|
|
url += `${item.month}/`;
|
|
}
|
|
|
|
return this.url_for(url);
|
|
};
|
|
|
|
result += `<ul class="archive-list">`;
|
|
|
|
for (let i = 0, len = data.length; i < Math.min(len, limit); i++) {
|
|
const item = data[i];
|
|
|
|
result += `<li class="archive-list-item">`;
|
|
|
|
result += `<a class="archive-list-link" href="${link(item)}">`;
|
|
result += `<span class="archive-list-date">`;
|
|
result += transform ? transform(item.name) : item.name;
|
|
result += `</span>`;
|
|
|
|
if (showCount) {
|
|
result += `<span class="archive-list-count">${item.count}</span>`;
|
|
}
|
|
result += "</a>";
|
|
result += "</li>";
|
|
}
|
|
|
|
if (data.length > limit) {
|
|
result += `<li class="archive-list-item">`;
|
|
result +=
|
|
`<a class="archive-list-link-more" href="` +
|
|
"/" +
|
|
`${archiveDir}" >`;
|
|
result += more_button;
|
|
result += "</a>";
|
|
result += "</li>";
|
|
}
|
|
result += "</ul>";
|
|
return result;
|
|
});
|