mirror of
https://github.com/wassname/template.git
synced 2026-06-27 23:09:26 +08:00
33 lines
1.1 KiB
JavaScript
33 lines
1.1 KiB
JavaScript
// import { Template } from '../mixins/template';
|
|
// import { Controller } from '../controller';
|
|
|
|
const isOnlyWhitespace = /^\s*$/;
|
|
|
|
export class Article extends HTMLElement {
|
|
static get is() { return 'd-article'; }
|
|
|
|
constructor() {
|
|
super();
|
|
|
|
new MutationObserver( (mutations) => {
|
|
for (const mutation of mutations) {
|
|
for (const addedNode of mutation.addedNodes) {
|
|
switch (addedNode.nodeName) {
|
|
case '#text': { // usually text nodes are only linebreaks.
|
|
const text = addedNode.nodeValue;
|
|
if (!isOnlyWhitespace.test(text)) {
|
|
console.warn('Use of unwrapped text in distill articles is discouraged as it breaks layout! Please wrap any text in a <span> or <p> tag. We found the following text: ' + text);
|
|
const wrapper = document.createElement('span');
|
|
wrapper.innerHTML = addedNode.nodeValue;
|
|
addedNode.parentNode.insertBefore(wrapper, addedNode);
|
|
addedNode.parentNode.removeChild(addedNode);
|
|
}
|
|
} break;
|
|
}
|
|
}
|
|
}
|
|
}).observe(this, {childList: true});
|
|
}
|
|
|
|
}
|