From 4a277188883270b68e7cb20095c91be597a38c32 Mon Sep 17 00:00:00 2001 From: Sasha Firsov Date: Mon, 1 Apr 2024 23:35:55 -0700 Subject: [PATCH] `observedAttributes` fix --- README.md | 3 ++- custom-element.js | 15 +++++++-------- 2 files changed, 9 insertions(+), 9 deletions(-) diff --git a/README.md b/README.md index 3892cb7..350d960 100644 --- a/README.md +++ b/README.md @@ -58,7 +58,8 @@ npm i -P @epa-wg/custom-element yarn add @epa-wg/custom-element ``` -## [enable IDE support](ide/IDE.md) +## Enable IDE support +[IDE.md](ide/IDE.md) diff --git a/custom-element.js b/custom-element.js index 799e180..9f08f70 100644 --- a/custom-element.js +++ b/custom-element.js @@ -436,16 +436,15 @@ CustomElement extends HTMLElement Object.defineProperty( this, "xsltString", { get: ()=>templateDocs.map( td => xmlString(td) ).join('\n') }); - const dce = this; - const sliceNames = [...this.templateNode.querySelectorAll('[slice]')].map(e=>attr(e,'slice')); + const dce = this + , sliceNodes = [...this.templateNode.querySelectorAll('[slice]')] + , sliceNames = sliceNodes.map(e=>attr(e,'slice')).filter(n=>!n.includes('/')) + , declaredAttributes = templateDocs.reduce( (ret,t) => { if( t.params ) ret.push( ...t.params ); return ret; }, [] ); + class DceElement extends HTMLElement { - static get observedAttributes() - { return templateDocs.reduce( (ret,t) => - { if( t.params ) ret.push( ...t.params.map(e=>attr(e,'name')) ); - return ret; - }, [] ); - } + static get observedAttributes(){ return declaredAttributes.map( a=>attr(a,'name')); } + connectedCallback() { if( this.firstElementChild?.tagName === 'TEMPLATE' ) { const t = this.firstElementChild;