mirror of
https://github.com/jerryc127/hexo-theme-butterfly.git
synced 2026-04-16 20:30:53 +08:00
improvement: 首頁社交圖標左右邊距調整 feat: 文章版權增加圖標 improvement: 重構 main.js 代碼 improvement: 優化 pjax 下的性能 fix: 修復子目錄下,pjax 跳轉 404 錯誤 feat: getScript 增加 attribute 配置 improvement: 優化手機端 toc 打開和關閉特效 improvement: 文章進入特效改為 transform, 優化 stylus improvement: 目錄側邊欄出現滾動條時,元素不會被擠壓 feat: 文章左右對齊 improvement: 處理 waline 的 url 後面多 / 導致跨域的問題 fix: 修復夜間模式下,小屏幕的toc 滾動條顏色不明顯的 bug fix: 修復設置字體超過17px時,toc 裏面的邊框異常的 bug improvement: 優化語言文件部分用詞 improvement: disqus 和 disqusjs 的評論數獲取不到時,顯示為 0 improvement: disqusjs 的評論數改為 api 獲取 improvement: 代碼優化 improvement: 更新 plugins.yml
100 lines
3.0 KiB
JavaScript
100 lines
3.0 KiB
JavaScript
/**
|
|
* Butterfly
|
|
* for aside categories
|
|
*/
|
|
|
|
'use strict'
|
|
|
|
hexo.extend.helper.register('aside_categories', function (categories, options) {
|
|
if (!options && (!categories || !Object.prototype.hasOwnProperty.call(categories, 'length'))
|
|
) {
|
|
options = categories
|
|
categories = this.site.categories
|
|
}
|
|
|
|
if (!categories || !categories.length) return ''
|
|
options = options || {}
|
|
const { config } = this
|
|
const showCount = Object.prototype.hasOwnProperty.call(options, 'show_count')
|
|
? options.show_count
|
|
: true
|
|
const depth = options.depth ? parseInt(options.depth, 10) : 0
|
|
const orderby = options.orderby || 'name'
|
|
const order = options.order || 1
|
|
const categoryDir = this.url_for(config.category_dir)
|
|
const limit = options.limit === 0 ? categories.length : options.limit
|
|
const isExpand = options.expand !== 'none'
|
|
const expandClass = isExpand && options.expand === true ? 'expand' : ''
|
|
const buttonLabel = this._p('aside.more_button')
|
|
const prepareQuery = (parent) => {
|
|
const query = {}
|
|
if (parent) { query.parent = parent } else { query.parent = { $exists: false } }
|
|
return categories.find(query).sort(orderby, order).filter((cat) => cat.length)
|
|
}
|
|
let expandBtn = ''
|
|
|
|
const hierarchicalList = (t, level, parent, topparent = true) => {
|
|
let result = ''
|
|
const isTopParent = topparent
|
|
if (t > 0) {
|
|
prepareQuery(parent).forEach((cat, i) => {
|
|
if (t > 0) {
|
|
t = t - 1
|
|
let child
|
|
if (!depth || level + 1 < depth) {
|
|
const childList = hierarchicalList(t, level + 1, cat._id, false)
|
|
child = childList[0]
|
|
t = childList[1]
|
|
}
|
|
|
|
const parentClass = isExpand && isTopParent && child ? 'parent' : ''
|
|
|
|
result += `<li class="card-category-list-item ${parentClass}">`
|
|
|
|
result += `<a class="card-category-list-link" href="${this.url_for(cat.path)}">`
|
|
|
|
result += `<span class="card-category-list-name">${cat.name}</span>`
|
|
|
|
if (showCount) {
|
|
result += `<span class="card-category-list-count">${cat.length}</span>`
|
|
}
|
|
|
|
if (isExpand && isTopParent && child) {
|
|
expandBtn = ' expandBtn'
|
|
result += `<i class="fas fa-caret-left ${expandClass}"></i>`
|
|
}
|
|
|
|
result += '</a>'
|
|
|
|
if (child) {
|
|
result += `<ul class="card-category-list child">${child}</ul>`
|
|
}
|
|
|
|
result += '</li>'
|
|
}
|
|
})
|
|
}
|
|
|
|
return [result, t]
|
|
}
|
|
|
|
const list = hierarchicalList(limit, 0)
|
|
|
|
const moreButton = function () {
|
|
if (categories.length <= limit) return ''
|
|
const moreHtml = `<a class="card-more-btn" href="${categoryDir}/" title="${buttonLabel}">
|
|
<i class="fas fa-angle-right"></i></a>`
|
|
|
|
return moreHtml
|
|
}
|
|
|
|
return `<div class="item-headline">
|
|
<i class="fas fa-folder-open"></i>
|
|
<span>${this._p('aside.card_categories')}</span>
|
|
${moreButton()}
|
|
</div>
|
|
<ul class="card-category-list${expandBtn}" id="aside-cat-list">
|
|
${list[0]}
|
|
</ul>`
|
|
})
|