UNPKG

hexo-theme-butterfly

Version:

A Simple and Card UI Design theme for Hexo

101 lines (84 loc) 3.44 kB
'use strict' hexo.extend.helper.register('aside_categories', function (categories, options = {}) { if (!categories || !Object.prototype.hasOwnProperty.call(categories, 'length')) { options = categories || {} categories = this.site.categories } if (!categories || !categories.length) return '' 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 || categories.length) const isExpand = options.expand !== 'none' const expandClass = isExpand && options.expand === true ? 'expand' : '' const buttonLabel = this._p('aside.more_button') const categoryMap = new Map() categories.forEach(cat => { if (cat.length) { const parentId = cat.parent || 'root' if (!categoryMap.has(parentId)) { categoryMap.set(parentId, []) } categoryMap.get(parentId).push(cat) } }) const sortFn = (a, b) => { const valA = a[orderby] const valB = b[orderby] if (valA < valB) return -order if (valA > valB) return order return 0 } for (const list of categoryMap.values()) { list.sort(sortFn) } const hierarchicalList = (remaining, level = 0, parentId = 'root') => { let result = '' if (remaining > 0 && categoryMap.has(parentId)) { categoryMap.get(parentId).forEach(cat => { if (remaining > 0) { remaining -= 1 let child = '' if (!depth || level + 1 < depth) { const childList = hierarchicalList(remaining, level + 1, cat._id) child = childList.result remaining = childList.remaining } const isTopLevel = parentId === 'root' const parentClass = isExpand && isTopLevel && 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 && isTopLevel && child) { 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, remaining } } const list = hierarchicalList(limit) const moreButton = categories.length > limit ? `<a class="card-more-btn" href="${categoryDir}/" title="${buttonLabel}"> <i class="fas fa-angle-right"></i></a>` : '' 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${isExpand && list.result ? ' expandBtn' : ''}" id="aside-cat-list"> ${list.result} </ul>` })