mirror of
https://github.com/wassname/template.git
synced 2026-06-30 01:41:17 +08:00
67 lines
1.3 KiB
JavaScript
67 lines
1.3 KiB
JavaScript
export class TOC extends HTMLElement {
|
|
|
|
static get is() { return 'd-toc'; }
|
|
|
|
connectedCallback() {
|
|
if (!this.getAttribute('prerendered')) {
|
|
window.onload = () => {
|
|
const article = document.querySelector('d-article');
|
|
const headings = article.querySelectorAll('h2, h3');
|
|
renderTOC(this, headings);
|
|
};
|
|
}
|
|
}
|
|
|
|
}
|
|
|
|
export function renderTOC(element, headings) {
|
|
|
|
let ToC =`
|
|
<style>
|
|
|
|
d-toc {
|
|
contain: content;
|
|
display: block;
|
|
}
|
|
|
|
d-toc ul {
|
|
padding-left: 0;
|
|
}
|
|
|
|
d-toc ul > ul {
|
|
padding-left: 24px;
|
|
}
|
|
|
|
d-toc a {
|
|
border-bottom: none;
|
|
text-decoration: none;
|
|
}
|
|
|
|
</style>
|
|
<nav role="navigation" class="table-of-contents"></nav>
|
|
<h2>Table of contents</h2>
|
|
<ul>`;
|
|
|
|
for (const el of headings) {
|
|
// should element be included in TOC?
|
|
const isInTitle = el.parentElement.tagName == 'D-TITLE';
|
|
const isException = el.getAttribute('no-toc');
|
|
if (isInTitle || isException) continue;
|
|
// create TOC entry
|
|
const title = el.textContent;
|
|
const link = '#' + el.getAttribute('id');
|
|
|
|
let newLine = '<li>' + '<a href="' + link + '">' + title + '</a>' + '</li>';
|
|
if (el.tagName == 'H3') {
|
|
newLine = '<ul>' + newLine + '</ul>';
|
|
} else {
|
|
newLine += '<br>';
|
|
}
|
|
ToC += newLine;
|
|
|
|
}
|
|
|
|
ToC += '</ul></nav>';
|
|
element.innerHTML = ToC;
|
|
}
|