mirror of
https://github.com/jerryc127/hexo-theme-butterfly.git
synced 2026-04-16 19:00: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
89 lines
2.7 KiB
JavaScript
89 lines
2.7 KiB
JavaScript
'use strict'
|
|
|
|
const { stripHTML, escapeHTML, prettyUrls } = require('hexo-util')
|
|
const crypto = require('crypto')
|
|
|
|
hexo.extend.helper.register('page_description', function () {
|
|
const { config, page } = this
|
|
let description = page.description || page.content || page.title || config.description
|
|
|
|
if (description) {
|
|
description = escapeHTML(stripHTML(description).substring(0, 150)
|
|
.trim()
|
|
).replace(/\n/g, ' ')
|
|
return description
|
|
}
|
|
})
|
|
|
|
hexo.extend.helper.register('cloudTags', function (options = {}) {
|
|
const env = this
|
|
let { source, minfontsize, maxfontsize, limit, unit, orderby, order } = options
|
|
unit = unit || 'px'
|
|
|
|
let result = ''
|
|
if (limit > 0) {
|
|
source = source.limit(limit)
|
|
}
|
|
|
|
const sizes = []
|
|
source.sort('length').forEach(tag => {
|
|
const { length } = tag
|
|
if (sizes.includes(length)) return
|
|
sizes.push(length)
|
|
})
|
|
|
|
const length = sizes.length - 1
|
|
source.sort(orderby, order).forEach(tag => {
|
|
const ratio = length ? sizes.indexOf(tag.length) / length : 0
|
|
const size = minfontsize + ((maxfontsize - minfontsize) * ratio)
|
|
let style = `font-size: ${parseFloat(size.toFixed(2))}${unit};`
|
|
const color = 'rgb(' + Math.floor(Math.random() * 201) + ', ' + Math.floor(Math.random() * 201) + ', ' + Math.floor(Math.random() * 201) + ')' // 0,0,0 -> 200,200,200
|
|
style += ` color: ${color}`
|
|
result += `<a href="${env.url_for(tag.path)}" style="${style}">${tag.name}</a>`
|
|
})
|
|
return result
|
|
})
|
|
|
|
hexo.extend.helper.register('urlNoIndex', function (url = null, trailingIndex = false, trailingHtml = false) {
|
|
return prettyUrls(url || this.url, { trailing_index: trailingIndex, trailing_html: trailingHtml })
|
|
})
|
|
|
|
hexo.extend.helper.register('md5', function (path) {
|
|
return crypto.createHash('md5').update(decodeURI(this.url_for(path))).digest('hex')
|
|
})
|
|
|
|
hexo.extend.helper.register('injectHtml', function (data) {
|
|
if (!data) return ''
|
|
return data.join('')
|
|
})
|
|
|
|
hexo.extend.helper.register('findArchivesTitle', function (page, menu, date) {
|
|
if (page.year) {
|
|
const dateStr = page.month ? `${page.year}-${page.month}` : `${page.year}`
|
|
const dateFormat = page.month ? hexo.theme.config.aside.card_archives.format : 'YYYY'
|
|
return date(dateStr, dateFormat)
|
|
}
|
|
|
|
const defaultTitle = this._p('page.archives')
|
|
if (!menu) return defaultTitle
|
|
|
|
const loop = (m) => {
|
|
for (const key in m) {
|
|
if (typeof m[key] === 'object') {
|
|
loop(m[key])
|
|
}
|
|
|
|
if (/\/archives\//.test(m[key])) {
|
|
return key
|
|
}
|
|
}
|
|
}
|
|
|
|
return loop(menu) || defaultTitle
|
|
})
|
|
|
|
hexo.extend.helper.register('isImgOrUrl', function (path) {
|
|
const imgTestReg = /\.(png|jpe?g|gif|svg|webp)(\?.*)?$/i
|
|
return path.indexOf('//') !== -1 || imgTestReg.test(path)
|
|
})
|