mirror of
https://github.com/docsifyjs/docsify.git
synced 2025-12-08 19:55:52 +00:00
93 lines
2.0 KiB
JavaScript
93 lines
2.0 KiB
JavaScript
import {isMobile} from '../util/env'
|
|
import * as dom from '../util/dom'
|
|
|
|
const title = dom.$.title
|
|
/**
|
|
* Toggle button
|
|
*/
|
|
export function btn(el) {
|
|
const toggle = _ => dom.body.classList.toggle('close')
|
|
|
|
el = dom.getNode(el)
|
|
if (el == null) {
|
|
return
|
|
}
|
|
dom.on(el, 'click', e => {
|
|
e.stopPropagation()
|
|
toggle()
|
|
})
|
|
|
|
isMobile &&
|
|
dom.on(
|
|
dom.body,
|
|
'click',
|
|
_ => dom.body.classList.contains('close') && toggle()
|
|
)
|
|
}
|
|
|
|
export function collapse(el) {
|
|
el = dom.getNode(el)
|
|
if (el == null) {
|
|
return
|
|
}
|
|
dom.on(el, 'click', ({target}) => {
|
|
if (
|
|
target.nodeName === 'A' &&
|
|
target.nextSibling &&
|
|
target.nextSibling.classList.contains('app-sub-sidebar')
|
|
) {
|
|
dom.toggleClass(target.parentNode, 'collapse')
|
|
}
|
|
})
|
|
}
|
|
|
|
export function sticky() {
|
|
const cover = dom.getNode('section.cover')
|
|
if (!cover) {
|
|
return
|
|
}
|
|
const coverHeight = cover.getBoundingClientRect().height
|
|
|
|
if (window.pageYOffset >= coverHeight || cover.classList.contains('hidden')) {
|
|
dom.toggleClass(dom.body, 'add', 'sticky')
|
|
} else {
|
|
dom.toggleClass(dom.body, 'remove', 'sticky')
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Get and active link
|
|
* @param {object} router
|
|
* @param {string|element} el
|
|
* @param {Boolean} isParent acitve parent
|
|
* @param {Boolean} autoTitle auto set title
|
|
* @return {element}
|
|
*/
|
|
export function getAndActive(router, el, isParent, autoTitle) {
|
|
el = dom.getNode(el)
|
|
let links = []
|
|
if (el != null) {
|
|
links = dom.findAll(el, 'a')
|
|
}
|
|
const hash = decodeURI(router.toURL(router.getCurrentPath()))
|
|
let target
|
|
|
|
links.sort((a, b) => b.href.length - a.href.length).forEach(a => {
|
|
const href = a.getAttribute('href')
|
|
const node = isParent ? a.parentNode : a
|
|
|
|
if (hash.indexOf(href) === 0 && !target) {
|
|
target = a
|
|
dom.toggleClass(node, 'add', 'active')
|
|
} else {
|
|
dom.toggleClass(node, 'remove', 'active')
|
|
}
|
|
})
|
|
|
|
if (autoTitle) {
|
|
dom.$.title = target ? (target.title || `${target.innerText} - ${title}`) : title
|
|
}
|
|
|
|
return target
|
|
}
|