132 lines
3.9 KiB
JavaScript
132 lines
3.9 KiB
JavaScript
/* global KEEP */
|
|
|
|
function initToggleShowToc() {
|
|
KEEP.utils.postHelper = {
|
|
postPageContainerDom: document.querySelector('.post-page-container'),
|
|
toggleShowTocBtnDom: document.querySelector('.toggle-show-toc'),
|
|
toggleShowTocIcon: document.querySelector('.toggle-show-toc i'),
|
|
mainContentDom: document.querySelector('.main-content'),
|
|
postToolsDom: document.querySelector('.post-tools'),
|
|
goToCommentsDom: document.querySelector('.post-tools .go-to-comments'),
|
|
|
|
isShowToc: false,
|
|
|
|
initToggleToc() {
|
|
this.toggleShowTocBtnDom &&
|
|
this.toggleShowTocBtnDom.addEventListener('click', () => {
|
|
this.isShowToc = !this.isShowToc
|
|
KEEP.styleStatus.isShowToc = this.isShowToc
|
|
KEEP.setStyleStatus()
|
|
this.handleToggleToc(this.isShowToc)
|
|
})
|
|
},
|
|
|
|
handleToggleToc(isOpen) {
|
|
if (isOpen) {
|
|
this.postPageContainerDom.classList.add('show-toc')
|
|
document.body.classList.add('has-toc')
|
|
} else {
|
|
this.postPageContainerDom.classList.remove('show-toc')
|
|
document.body.classList.remove('has-toc')
|
|
}
|
|
|
|
setTimeout(() => {
|
|
this.setPostToolsLeft()
|
|
}, 120)
|
|
},
|
|
|
|
hasToc(isOpen) {
|
|
this.toggleShowTocBtnDom.style.display = 'flex'
|
|
this.isShowToc = isOpen
|
|
this.handleToggleToc(isOpen)
|
|
},
|
|
|
|
setPostToolsLeft(mcw) {
|
|
const mainContainerWidth = mcw
|
|
? mcw
|
|
: this.mainContentDom.getBoundingClientRect().width.toFixed(0)
|
|
let offsetX = 5
|
|
|
|
if (window.innerWidth <= 800) {
|
|
offsetX = 3
|
|
}
|
|
|
|
this.postToolsDom.style.opacity = `1`
|
|
this.postToolsDom.style.left = `calc((100vw - ${mainContainerWidth}px) / 2 - ${offsetX}rem)`
|
|
},
|
|
|
|
initSetPostToolsLeft() {
|
|
setTimeout(() => {
|
|
this.setPostToolsLeft()
|
|
}, 150)
|
|
|
|
window.addEventListener('resize', () => {
|
|
this.setPostToolsLeft()
|
|
})
|
|
},
|
|
|
|
// go comment anchor
|
|
goToComments() {
|
|
const commentsAnchor = document.querySelector('#comments-anchor')
|
|
if (this.goToCommentsDom && commentsAnchor) {
|
|
this.goToCommentsDom.addEventListener('click', (event) => {
|
|
event.preventDefault()
|
|
let winScrollY = window.scrollY
|
|
winScrollY = winScrollY === 0 ? -20 : winScrollY
|
|
const offset = commentsAnchor.getBoundingClientRect().top + winScrollY
|
|
window.anime({
|
|
targets: document.scrollingElement,
|
|
duration: 300,
|
|
easing: 'linear',
|
|
scrollTop: offset,
|
|
complete: () => {
|
|
setTimeout(() => {
|
|
KEEP.utils.pageTop_dom.classList.add('hide')
|
|
}, 150)
|
|
}
|
|
})
|
|
})
|
|
}
|
|
},
|
|
|
|
// watch comments count
|
|
watchPostCommentsCount() {
|
|
const commentsCountDom = this.postToolsDom.querySelector('.post-comments-count')
|
|
if (!commentsCountDom) return
|
|
const config = { attributes: true, childList: true }
|
|
|
|
const callback = function (mutationsList) {
|
|
mutationsList.forEach((item) => {
|
|
if (item.type === 'childList') {
|
|
const count = Number(item.target.innerHTML)
|
|
if (count > 0) {
|
|
commentsCountDom.style.display = 'flex'
|
|
if (count > 99) {
|
|
commentsCountDom.innerHTML = '99+'
|
|
observer.disconnect()
|
|
}
|
|
}
|
|
}
|
|
})
|
|
}
|
|
|
|
const observer = new MutationObserver(callback)
|
|
observer.observe(commentsCountDom, config)
|
|
}
|
|
}
|
|
KEEP.utils.postHelper.initSetPostToolsLeft()
|
|
if (KEEP.theme_config.toc.enable === true) {
|
|
KEEP.utils.postHelper.initToggleToc()
|
|
}
|
|
if (KEEP.theme_config.comment.enable === true) {
|
|
KEEP.utils.postHelper.goToComments()
|
|
KEEP.utils.postHelper.watchPostCommentsCount()
|
|
}
|
|
}
|
|
|
|
if (KEEP.theme_config.pjax.enable === true && KEEP.utils) {
|
|
initToggleShowToc()
|
|
} else {
|
|
window.addEventListener('DOMContentLoaded', initToggleShowToc)
|
|
}
|