const template = document.createElement('template'); template.innerHTML = `

says:

` class comment extends HTMLElement { constructor() { super(); this._shadowRoot = this.attachShadow({ 'mode': 'open' }); this._shadowRoot.appendChild(template.content.cloneNode(true)); this.$comment = this._shadowRoot.querySelector('#commentContainer'); } static get observedAttributes() { return ['author_name', 'author_url', 'avatar_url', 'comment_content', 'publish_date']; } attributeChangedCallback(name, oldVal, newVal) { if (oldVal != newVal) { this[name] = newVal; this.render(); } } render() { this.$comment.querySelector('#author-link').innerHTML = this.author_name; this.$comment.querySelector('#author-link').href = this.author_url; this.$comment.querySelector('wc-profile-pic').setAttribute('url', this.avatar_url) this.$comment.querySelector('#comment').innerHTML = this.comment_content; this.$comment.querySelector('#publish-date').innerHTML = this.publish_date; } } window.customElements.define('wc-comment', comment);