@dooboostore/dom-parser 1.0.2 → 1.0.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.MD +369 -6
- package/dist/cjs/DomParser.js +11 -1
- package/dist/cjs/DomParser.js.map +2 -2
- package/dist/cjs/bundle-entry.js +36 -0
- package/dist/cjs/bundle-entry.js.map +7 -0
- package/dist/cjs/factory/ElementFactory.js +31 -7
- package/dist/cjs/factory/ElementFactory.js.map +2 -2
- package/dist/cjs/index.js +26 -0
- package/dist/cjs/index.js.map +2 -2
- package/dist/cjs/node/CharacterData.js.map +1 -1
- package/dist/cjs/node/ChildNode.js +0 -15
- package/dist/cjs/node/ChildNode.js.map +3 -3
- package/dist/cjs/node/ChildNodeBase.js +20 -0
- package/dist/cjs/node/ChildNodeBase.js.map +2 -2
- package/dist/cjs/node/Comment.js.map +2 -2
- package/dist/cjs/node/Document.js +0 -27
- package/dist/cjs/node/Document.js.map +4 -4
- package/dist/cjs/node/DocumentBase.js +168 -205
- package/dist/cjs/node/DocumentBase.js.map +2 -2
- package/dist/cjs/node/DocumentFragment.js +0 -15
- package/dist/cjs/node/DocumentFragment.js.map +3 -3
- package/dist/cjs/node/DocumentFragmentBase.js.map +2 -2
- package/dist/cjs/node/Node.js.map +1 -1
- package/dist/cjs/node/NodeBase.js +44 -2
- package/dist/cjs/node/NodeBase.js.map +2 -2
- package/dist/cjs/node/NodeFilter.js +43 -0
- package/dist/cjs/node/NodeFilter.js.map +7 -0
- package/dist/cjs/node/NodeIterator.js +1 -28
- package/dist/cjs/node/NodeIterator.js.map +2 -2
- package/dist/cjs/node/ParentNode.js +0 -15
- package/dist/cjs/node/ParentNode.js.map +3 -3
- package/dist/cjs/node/ParentNodeBase.js +10 -10
- package/dist/cjs/node/ParentNodeBase.js.map +3 -3
- package/dist/cjs/node/ShadowRootBase.js +79 -0
- package/dist/cjs/node/ShadowRootBase.js.map +7 -0
- package/dist/cjs/node/Text.js +0 -15
- package/dist/cjs/node/Text.js.map +3 -3
- package/dist/cjs/node/TextBase.js +0 -3
- package/dist/cjs/node/TextBase.js.map +2 -2
- package/dist/cjs/node/TreeWalker.js +272 -0
- package/dist/cjs/node/TreeWalker.js.map +7 -0
- package/dist/cjs/node/collection/{HTMLCollection.js → HTMLCollectionImp.js} +7 -6
- package/dist/cjs/node/collection/HTMLCollectionImp.js.map +7 -0
- package/dist/cjs/node/collection/HTMLCollectionOfImp.js +26 -0
- package/dist/cjs/node/collection/HTMLCollectionOfImp.js.map +7 -0
- package/dist/cjs/node/collection/NodeList.js.map +1 -1
- package/dist/cjs/node/collection/{NodeListOf.js → NodeListOfImp.js} +6 -6
- package/dist/cjs/node/collection/NodeListOfImp.js.map +7 -0
- package/dist/cjs/node/collection/StylePropertyMapImpl.js +65 -0
- package/dist/cjs/node/collection/StylePropertyMapImpl.js.map +7 -0
- package/dist/cjs/node/collection/index.js +6 -6
- package/dist/cjs/node/collection/index.js.map +2 -2
- package/dist/cjs/node/elements/Element.js +0 -15
- package/dist/cjs/node/elements/Element.js.map +3 -3
- package/dist/cjs/node/elements/ElementBase.js +163 -331
- package/dist/cjs/node/elements/ElementBase.js.map +3 -3
- package/dist/cjs/node/elements/HTMLAnchorElement.js +2 -2
- package/dist/cjs/node/elements/HTMLAnchorElement.js.map +2 -2
- package/dist/cjs/node/elements/HTMLAreaElement.js +2 -2
- package/dist/cjs/node/elements/HTMLAreaElement.js.map +2 -2
- package/dist/cjs/node/elements/{HTMLGenericElement.js → HTMLAudioElement.js} +8 -11
- package/dist/cjs/node/elements/HTMLAudioElement.js.map +7 -0
- package/dist/cjs/node/elements/HTMLBaseElement.js +2 -2
- package/dist/cjs/node/elements/HTMLBaseElement.js.map +2 -2
- package/dist/cjs/node/elements/HTMLBodyElement.js +2 -2
- package/dist/cjs/node/elements/HTMLBodyElement.js.map +2 -2
- package/dist/cjs/node/elements/HTMLButtonElement.js +3 -3
- package/dist/cjs/node/elements/HTMLButtonElement.js.map +2 -2
- package/dist/cjs/node/elements/HTMLCanvasElement.js +2 -2
- package/dist/cjs/node/elements/HTMLCanvasElement.js.map +2 -2
- package/dist/cjs/node/elements/HTMLCaptionElement.js +2 -2
- package/dist/cjs/node/elements/HTMLCaptionElement.js.map +2 -2
- package/dist/cjs/node/{collection/HTMLCollectionOf.js → elements/HTMLDListElement.js} +9 -16
- package/dist/cjs/node/elements/HTMLDListElement.js.map +7 -0
- package/dist/cjs/node/elements/HTMLDataElement.js +29 -0
- package/dist/cjs/node/elements/HTMLDataElement.js.map +7 -0
- package/dist/cjs/node/elements/HTMLDataListElement.js +29 -0
- package/dist/cjs/node/elements/HTMLDataListElement.js.map +7 -0
- package/dist/cjs/node/elements/HTMLDetailsElement.js +29 -0
- package/dist/cjs/node/elements/HTMLDetailsElement.js.map +7 -0
- package/dist/cjs/node/elements/HTMLDialogElement.js +29 -0
- package/dist/cjs/node/elements/HTMLDialogElement.js.map +7 -0
- package/dist/cjs/node/elements/HTMLDivElement.js +2 -2
- package/dist/cjs/node/elements/HTMLDivElement.js.map +2 -2
- package/dist/cjs/node/elements/HTMLElement.js +13 -0
- package/dist/cjs/node/elements/HTMLElement.js.map +2 -2
- package/dist/cjs/node/elements/HTMLElementBase.js +44 -44
- package/dist/cjs/node/elements/HTMLElementBase.js.map +2 -2
- package/dist/cjs/node/elements/HTMLEmbedElement.js +2 -2
- package/dist/cjs/node/elements/HTMLEmbedElement.js.map +2 -2
- package/dist/cjs/node/elements/HTMLFieldSetElement.js +29 -0
- package/dist/cjs/node/elements/HTMLFieldSetElement.js.map +7 -0
- package/dist/cjs/node/elements/HTMLFormElement.js +2 -2
- package/dist/cjs/node/elements/HTMLFormElement.js.map +2 -2
- package/dist/cjs/node/elements/HTMLH1Element.js +2 -2
- package/dist/cjs/node/elements/HTMLH1Element.js.map +2 -2
- package/dist/cjs/node/elements/HTMLHRElement.js +29 -0
- package/dist/cjs/node/elements/HTMLHRElement.js.map +7 -0
- package/dist/cjs/node/elements/HTMLHeadElement.js +2 -2
- package/dist/cjs/node/elements/HTMLHeadElement.js.map +2 -2
- package/dist/cjs/node/elements/HTMLHtmlElement.js +2 -2
- package/dist/cjs/node/elements/HTMLHtmlElement.js.map +2 -2
- package/dist/cjs/node/elements/HTMLIFrameElement.js +29 -0
- package/dist/cjs/node/elements/HTMLIFrameElement.js.map +7 -0
- package/dist/cjs/node/elements/HTMLImgElement.js +2 -2
- package/dist/cjs/node/elements/HTMLImgElement.js.map +2 -2
- package/dist/cjs/node/elements/HTMLInputElement.js +2 -2
- package/dist/cjs/node/elements/HTMLInputElement.js.map +2 -2
- package/dist/cjs/node/elements/HTMLLIElement.js +2 -2
- package/dist/cjs/node/elements/HTMLLIElement.js.map +2 -2
- package/dist/cjs/node/elements/HTMLLabelElement.js +29 -0
- package/dist/cjs/node/elements/HTMLLabelElement.js.map +7 -0
- package/dist/cjs/node/elements/HTMLLegendElement.js +29 -0
- package/dist/cjs/node/elements/HTMLLegendElement.js.map +7 -0
- package/dist/cjs/node/elements/HTMLLinkElement.js +2 -2
- package/dist/cjs/node/elements/HTMLLinkElement.js.map +2 -2
- package/dist/cjs/node/elements/HTMLMapElement.js +29 -0
- package/dist/cjs/node/elements/HTMLMapElement.js.map +7 -0
- package/dist/cjs/node/elements/HTMLMetaElement.js +2 -2
- package/dist/cjs/node/elements/HTMLMetaElement.js.map +2 -2
- package/dist/cjs/node/elements/HTMLMeterElement.js +29 -0
- package/dist/cjs/node/elements/HTMLMeterElement.js.map +7 -0
- package/dist/cjs/node/elements/HTMLModElement.js +29 -0
- package/dist/cjs/node/elements/HTMLModElement.js.map +7 -0
- package/dist/cjs/node/elements/HTMLOListElement.js +2 -2
- package/dist/cjs/node/elements/HTMLOListElement.js.map +2 -2
- package/dist/cjs/node/elements/HTMLObjectElement.js +29 -0
- package/dist/cjs/node/elements/HTMLObjectElement.js.map +7 -0
- package/dist/cjs/node/elements/HTMLOptGroupElement.js +29 -0
- package/dist/cjs/node/elements/HTMLOptGroupElement.js.map +7 -0
- package/dist/cjs/node/elements/HTMLOptionElement.js +29 -0
- package/dist/cjs/node/elements/HTMLOptionElement.js.map +7 -0
- package/dist/cjs/node/elements/HTMLOutputElement.js +29 -0
- package/dist/cjs/node/elements/HTMLOutputElement.js.map +7 -0
- package/dist/cjs/node/elements/HTMLPElement.js +2 -2
- package/dist/cjs/node/elements/HTMLPElement.js.map +2 -2
- package/dist/cjs/node/elements/HTMLParamElement.js +29 -0
- package/dist/cjs/node/elements/HTMLParamElement.js.map +7 -0
- package/dist/cjs/node/elements/HTMLPictureElement.js +29 -0
- package/dist/cjs/node/elements/HTMLPictureElement.js.map +7 -0
- package/dist/cjs/node/elements/HTMLPreElement.js +29 -0
- package/dist/cjs/node/elements/HTMLPreElement.js.map +7 -0
- package/dist/cjs/node/elements/HTMLProgressElement.js +29 -0
- package/dist/cjs/node/elements/HTMLProgressElement.js.map +7 -0
- package/dist/cjs/node/elements/HTMLQuoteElement.js +29 -0
- package/dist/cjs/node/elements/HTMLQuoteElement.js.map +7 -0
- package/dist/cjs/node/elements/HTMLScriptElement.js +2 -2
- package/dist/cjs/node/elements/HTMLScriptElement.js.map +2 -2
- package/dist/cjs/node/elements/HTMLSelectElement.js +29 -0
- package/dist/cjs/node/elements/HTMLSelectElement.js.map +7 -0
- package/dist/cjs/node/elements/HTMLSlotElement.js +29 -0
- package/dist/cjs/node/elements/HTMLSlotElement.js.map +7 -0
- package/dist/cjs/node/elements/HTMLSourceElement.js +29 -0
- package/dist/cjs/node/elements/HTMLSourceElement.js.map +7 -0
- package/dist/cjs/node/elements/HTMLSpanElement.js +2 -2
- package/dist/cjs/node/elements/HTMLSpanElement.js.map +2 -2
- package/dist/cjs/node/elements/HTMLStyleElement.js +2 -2
- package/dist/cjs/node/elements/HTMLStyleElement.js.map +2 -2
- package/dist/cjs/node/elements/HTMLTableElement.js +2 -2
- package/dist/cjs/node/elements/HTMLTableElement.js.map +2 -2
- package/dist/cjs/node/elements/HTMLTbodyElement.js +2 -2
- package/dist/cjs/node/elements/HTMLTbodyElement.js.map +2 -2
- package/dist/cjs/node/elements/HTMLTdElement.js +2 -2
- package/dist/cjs/node/elements/HTMLTdElement.js.map +2 -2
- package/dist/cjs/node/elements/HTMLTemplateElement.js +2 -2
- package/dist/cjs/node/elements/HTMLTemplateElement.js.map +2 -2
- package/dist/cjs/node/elements/HTMLTextAreaElement.js +29 -0
- package/dist/cjs/node/elements/HTMLTextAreaElement.js.map +7 -0
- package/dist/cjs/node/elements/HTMLTfootElement.js +2 -2
- package/dist/cjs/node/elements/HTMLTfootElement.js.map +2 -2
- package/dist/cjs/node/elements/HTMLThElement.js +2 -2
- package/dist/cjs/node/elements/HTMLThElement.js.map +2 -2
- package/dist/cjs/node/elements/HTMLTheadElement.js +2 -2
- package/dist/cjs/node/elements/HTMLTheadElement.js.map +2 -2
- package/dist/cjs/node/elements/HTMLTimeElement.js +29 -0
- package/dist/cjs/node/elements/HTMLTimeElement.js.map +7 -0
- package/dist/cjs/node/elements/HTMLTitleElement.js +2 -2
- package/dist/cjs/node/elements/HTMLTitleElement.js.map +2 -2
- package/dist/cjs/node/elements/HTMLTrElement.js +2 -2
- package/dist/cjs/node/elements/HTMLTrElement.js.map +2 -2
- package/dist/cjs/node/elements/HTMLTrackElement.js +29 -0
- package/dist/cjs/node/elements/HTMLTrackElement.js.map +7 -0
- package/dist/cjs/node/elements/HTMLUListElement.js +2 -2
- package/dist/cjs/node/elements/HTMLUListElement.js.map +2 -2
- package/dist/cjs/node/elements/HTMLVideoElement.js +29 -0
- package/dist/cjs/node/elements/HTMLVideoElement.js.map +7 -0
- package/dist/cjs/node/elements/MathMLElement.js +2 -2
- package/dist/cjs/node/elements/MathMLElement.js.map +2 -2
- package/dist/cjs/node/elements/SVGElement.js +2 -2
- package/dist/cjs/node/elements/SVGElement.js.map +2 -2
- package/dist/cjs/node/elements/index.js +181 -94
- package/dist/cjs/node/elements/index.js.map +2 -2
- package/dist/cjs/node/index.js +6 -16
- package/dist/cjs/node/index.js.map +2 -2
- package/dist/cjs/utils/CSSSelector.js.map +2 -2
- package/dist/cjs/window/CustomElementRegistryImp.js +113 -0
- package/dist/cjs/window/CustomElementRegistryImp.js.map +7 -0
- package/dist/cjs/window/Window.js +0 -15
- package/dist/cjs/window/Window.js.map +3 -3
- package/dist/cjs/window/WindowBase.js +210 -613
- package/dist/cjs/window/WindowBase.js.map +2 -2
- package/dist/cjs/window/index.js +0 -5
- package/dist/cjs/window/index.js.map +2 -2
- package/dist/esm/DomParser.js +11 -1
- package/dist/esm/DomParser.js.map +2 -2
- package/dist/esm/bundle-entry.js +6 -0
- package/dist/esm/bundle-entry.js.map +7 -0
- package/dist/esm/factory/ElementFactory.js +32 -8
- package/dist/esm/factory/ElementFactory.js.map +2 -2
- package/dist/esm/index.js +26 -0
- package/dist/esm/index.js.map +2 -2
- package/dist/esm/node/ChildNodeBase.js +20 -0
- package/dist/esm/node/ChildNodeBase.js.map +2 -2
- package/dist/esm/node/Comment.js.map +2 -2
- package/dist/esm/node/Document.js +0 -8
- package/dist/esm/node/Document.js.map +4 -4
- package/dist/esm/node/DocumentBase.js +165 -202
- package/dist/esm/node/DocumentBase.js.map +2 -2
- package/dist/esm/node/DocumentFragmentBase.js.map +2 -2
- package/dist/esm/node/Node.js.map +1 -1
- package/dist/esm/node/NodeBase.js +45 -22
- package/dist/esm/node/NodeBase.js.map +2 -2
- package/dist/esm/node/NodeFilter.js +24 -0
- package/dist/esm/node/NodeFilter.js.map +7 -0
- package/dist/esm/node/NodeIterator.js +1 -28
- package/dist/esm/node/NodeIterator.js.map +2 -2
- package/dist/esm/node/ParentNodeBase.js +4 -4
- package/dist/esm/node/ParentNodeBase.js.map +2 -2
- package/dist/esm/node/ShadowRootBase.js +60 -0
- package/dist/esm/node/ShadowRootBase.js.map +7 -0
- package/dist/esm/node/TextBase.js +0 -3
- package/dist/esm/node/TextBase.js.map +2 -2
- package/dist/esm/node/TreeWalker.js +253 -0
- package/dist/esm/node/TreeWalker.js.map +7 -0
- package/dist/esm/node/collection/{HTMLCollection.js → HTMLCollectionImp.js} +4 -3
- package/dist/esm/node/collection/HTMLCollectionImp.js.map +7 -0
- package/dist/esm/node/collection/HTMLCollectionOfImp.js +7 -0
- package/dist/esm/node/collection/HTMLCollectionOfImp.js.map +7 -0
- package/dist/esm/node/collection/NodeList.js.map +1 -1
- package/dist/esm/node/collection/{NodeListOf.js → NodeListOfImp.js} +3 -3
- package/dist/esm/node/collection/NodeListOfImp.js.map +7 -0
- package/dist/esm/node/collection/StylePropertyMapImpl.js +46 -0
- package/dist/esm/node/collection/StylePropertyMapImpl.js.map +7 -0
- package/dist/esm/node/collection/index.js +6 -6
- package/dist/esm/node/collection/index.js.map +2 -2
- package/dist/esm/node/elements/ElementBase.js +163 -331
- package/dist/esm/node/elements/ElementBase.js.map +3 -3
- package/dist/esm/node/elements/HTMLAnchorElement.js +2 -2
- package/dist/esm/node/elements/HTMLAnchorElement.js.map +2 -2
- package/dist/esm/node/elements/HTMLAreaElement.js +2 -2
- package/dist/esm/node/elements/HTMLAreaElement.js.map +2 -2
- package/dist/esm/node/elements/HTMLAudioElement.js +10 -0
- package/dist/esm/node/elements/HTMLAudioElement.js.map +7 -0
- package/dist/esm/node/elements/HTMLBaseElement.js +2 -2
- package/dist/esm/node/elements/HTMLBaseElement.js.map +2 -2
- package/dist/esm/node/elements/HTMLBodyElement.js +2 -2
- package/dist/esm/node/elements/HTMLBodyElement.js.map +2 -2
- package/dist/esm/node/elements/HTMLButtonElement.js +3 -3
- package/dist/esm/node/elements/HTMLButtonElement.js.map +2 -2
- package/dist/esm/node/elements/HTMLCanvasElement.js +2 -2
- package/dist/esm/node/elements/HTMLCanvasElement.js.map +2 -2
- package/dist/esm/node/elements/HTMLCaptionElement.js +2 -2
- package/dist/esm/node/elements/HTMLCaptionElement.js.map +2 -2
- package/dist/esm/node/elements/HTMLDListElement.js +10 -0
- package/dist/esm/node/elements/HTMLDListElement.js.map +7 -0
- package/dist/esm/node/elements/HTMLDataElement.js +10 -0
- package/dist/esm/node/elements/HTMLDataElement.js.map +7 -0
- package/dist/esm/node/elements/HTMLDataListElement.js +10 -0
- package/dist/esm/node/elements/HTMLDataListElement.js.map +7 -0
- package/dist/esm/node/elements/HTMLDetailsElement.js +10 -0
- package/dist/esm/node/elements/HTMLDetailsElement.js.map +7 -0
- package/dist/esm/node/elements/HTMLDialogElement.js +10 -0
- package/dist/esm/node/elements/HTMLDialogElement.js.map +7 -0
- package/dist/esm/node/elements/HTMLDivElement.js +2 -2
- package/dist/esm/node/elements/HTMLDivElement.js.map +2 -2
- package/dist/esm/node/elements/HTMLElement.js +9 -0
- package/dist/esm/node/elements/HTMLElement.js.map +3 -3
- package/dist/esm/node/elements/HTMLElementBase.js +43 -43
- package/dist/esm/node/elements/HTMLElementBase.js.map +2 -2
- package/dist/esm/node/elements/HTMLEmbedElement.js +2 -2
- package/dist/esm/node/elements/HTMLEmbedElement.js.map +2 -2
- package/dist/esm/node/elements/HTMLFieldSetElement.js +10 -0
- package/dist/esm/node/elements/HTMLFieldSetElement.js.map +7 -0
- package/dist/esm/node/elements/HTMLFormElement.js +2 -2
- package/dist/esm/node/elements/HTMLFormElement.js.map +2 -2
- package/dist/esm/node/elements/HTMLH1Element.js +2 -2
- package/dist/esm/node/elements/HTMLH1Element.js.map +2 -2
- package/dist/esm/node/elements/HTMLHRElement.js +10 -0
- package/dist/esm/node/elements/HTMLHRElement.js.map +7 -0
- package/dist/esm/node/elements/HTMLHeadElement.js +2 -2
- package/dist/esm/node/elements/HTMLHeadElement.js.map +2 -2
- package/dist/esm/node/elements/HTMLHtmlElement.js +2 -2
- package/dist/esm/node/elements/HTMLHtmlElement.js.map +2 -2
- package/dist/esm/node/elements/HTMLIFrameElement.js +10 -0
- package/dist/esm/node/elements/HTMLIFrameElement.js.map +7 -0
- package/dist/esm/node/elements/HTMLImgElement.js +2 -2
- package/dist/esm/node/elements/HTMLImgElement.js.map +2 -2
- package/dist/esm/node/elements/HTMLInputElement.js +2 -2
- package/dist/esm/node/elements/HTMLInputElement.js.map +2 -2
- package/dist/esm/node/elements/HTMLLIElement.js +2 -2
- package/dist/esm/node/elements/HTMLLIElement.js.map +2 -2
- package/dist/esm/node/elements/HTMLLabelElement.js +10 -0
- package/dist/esm/node/elements/HTMLLabelElement.js.map +7 -0
- package/dist/esm/node/elements/HTMLLegendElement.js +10 -0
- package/dist/esm/node/elements/HTMLLegendElement.js.map +7 -0
- package/dist/esm/node/elements/HTMLLinkElement.js +2 -2
- package/dist/esm/node/elements/HTMLLinkElement.js.map +2 -2
- package/dist/esm/node/elements/HTMLMapElement.js +10 -0
- package/dist/esm/node/elements/HTMLMapElement.js.map +7 -0
- package/dist/esm/node/elements/HTMLMetaElement.js +2 -2
- package/dist/esm/node/elements/HTMLMetaElement.js.map +2 -2
- package/dist/esm/node/elements/HTMLMeterElement.js +10 -0
- package/dist/esm/node/elements/HTMLMeterElement.js.map +7 -0
- package/dist/esm/node/elements/HTMLModElement.js +10 -0
- package/dist/esm/node/elements/HTMLModElement.js.map +7 -0
- package/dist/esm/node/elements/HTMLOListElement.js +2 -2
- package/dist/esm/node/elements/HTMLOListElement.js.map +2 -2
- package/dist/esm/node/elements/HTMLObjectElement.js +10 -0
- package/dist/esm/node/elements/HTMLObjectElement.js.map +7 -0
- package/dist/esm/node/elements/HTMLOptGroupElement.js +10 -0
- package/dist/esm/node/elements/HTMLOptGroupElement.js.map +7 -0
- package/dist/esm/node/elements/HTMLOptionElement.js +10 -0
- package/dist/esm/node/elements/HTMLOptionElement.js.map +7 -0
- package/dist/esm/node/elements/HTMLOutputElement.js +10 -0
- package/dist/esm/node/elements/HTMLOutputElement.js.map +7 -0
- package/dist/esm/node/elements/HTMLPElement.js +2 -2
- package/dist/esm/node/elements/HTMLPElement.js.map +2 -2
- package/dist/esm/node/elements/HTMLParamElement.js +10 -0
- package/dist/esm/node/elements/HTMLParamElement.js.map +7 -0
- package/dist/esm/node/elements/HTMLPictureElement.js +10 -0
- package/dist/esm/node/elements/HTMLPictureElement.js.map +7 -0
- package/dist/esm/node/elements/HTMLPreElement.js +10 -0
- package/dist/esm/node/elements/HTMLPreElement.js.map +7 -0
- package/dist/esm/node/elements/HTMLProgressElement.js +10 -0
- package/dist/esm/node/elements/HTMLProgressElement.js.map +7 -0
- package/dist/esm/node/elements/HTMLQuoteElement.js +10 -0
- package/dist/esm/node/elements/HTMLQuoteElement.js.map +7 -0
- package/dist/esm/node/elements/HTMLScriptElement.js +2 -2
- package/dist/esm/node/elements/HTMLScriptElement.js.map +2 -2
- package/dist/esm/node/elements/HTMLSelectElement.js +10 -0
- package/dist/esm/node/elements/HTMLSelectElement.js.map +7 -0
- package/dist/esm/node/elements/HTMLSlotElement.js +10 -0
- package/dist/esm/node/elements/HTMLSlotElement.js.map +7 -0
- package/dist/esm/node/elements/HTMLSourceElement.js +10 -0
- package/dist/esm/node/elements/HTMLSourceElement.js.map +7 -0
- package/dist/esm/node/elements/HTMLSpanElement.js +2 -2
- package/dist/esm/node/elements/HTMLSpanElement.js.map +2 -2
- package/dist/esm/node/elements/HTMLStyleElement.js +2 -2
- package/dist/esm/node/elements/HTMLStyleElement.js.map +2 -2
- package/dist/esm/node/elements/HTMLTableElement.js +2 -2
- package/dist/esm/node/elements/HTMLTableElement.js.map +2 -2
- package/dist/esm/node/elements/HTMLTbodyElement.js +2 -2
- package/dist/esm/node/elements/HTMLTbodyElement.js.map +2 -2
- package/dist/esm/node/elements/HTMLTdElement.js +2 -2
- package/dist/esm/node/elements/HTMLTdElement.js.map +2 -2
- package/dist/esm/node/elements/HTMLTemplateElement.js +2 -2
- package/dist/esm/node/elements/HTMLTemplateElement.js.map +2 -2
- package/dist/esm/node/elements/HTMLTextAreaElement.js +10 -0
- package/dist/esm/node/elements/HTMLTextAreaElement.js.map +7 -0
- package/dist/esm/node/elements/HTMLTfootElement.js +2 -2
- package/dist/esm/node/elements/HTMLTfootElement.js.map +2 -2
- package/dist/esm/node/elements/HTMLThElement.js +2 -2
- package/dist/esm/node/elements/HTMLThElement.js.map +2 -2
- package/dist/esm/node/elements/HTMLTheadElement.js +2 -2
- package/dist/esm/node/elements/HTMLTheadElement.js.map +2 -2
- package/dist/esm/node/elements/HTMLTimeElement.js +10 -0
- package/dist/esm/node/elements/HTMLTimeElement.js.map +7 -0
- package/dist/esm/node/elements/HTMLTitleElement.js +2 -2
- package/dist/esm/node/elements/HTMLTitleElement.js.map +2 -2
- package/dist/esm/node/elements/HTMLTrElement.js +2 -2
- package/dist/esm/node/elements/HTMLTrElement.js.map +2 -2
- package/dist/esm/node/elements/HTMLTrackElement.js +10 -0
- package/dist/esm/node/elements/HTMLTrackElement.js.map +7 -0
- package/dist/esm/node/elements/HTMLUListElement.js +2 -2
- package/dist/esm/node/elements/HTMLUListElement.js.map +2 -2
- package/dist/esm/node/elements/HTMLVideoElement.js +10 -0
- package/dist/esm/node/elements/HTMLVideoElement.js.map +7 -0
- package/dist/esm/node/elements/MathMLElement.js +2 -2
- package/dist/esm/node/elements/MathMLElement.js.map +2 -2
- package/dist/esm/node/elements/SVGElement.js +2 -2
- package/dist/esm/node/elements/SVGElement.js.map +2 -2
- package/dist/esm/node/elements/index.js +182 -95
- package/dist/esm/node/elements/index.js.map +2 -2
- package/dist/esm/node/index.js +7 -17
- package/dist/esm/node/index.js.map +2 -2
- package/dist/esm/utils/CSSSelector.js.map +2 -2
- package/dist/esm/window/CustomElementRegistryImp.js +94 -0
- package/dist/esm/window/CustomElementRegistryImp.js.map +7 -0
- package/dist/esm/window/WindowBase.js +259 -597
- package/dist/esm/window/WindowBase.js.map +2 -2
- package/dist/esm/window/index.js +0 -5
- package/dist/esm/window/index.js.map +2 -2
- package/dist/esm-bundle/dooboostore-dom-parser.esm.js +3477 -3558
- package/dist/esm-bundle/dooboostore-dom-parser.esm.js.map +4 -4
- package/dist/types/DomParser.d.ts.map +1 -1
- package/dist/types/bundle-entry.d.ts +3 -0
- package/dist/types/bundle-entry.d.ts.map +1 -0
- package/dist/types/factory/ElementFactory.d.ts +1 -1
- package/dist/types/factory/ElementFactory.d.ts.map +1 -1
- package/dist/types/index.d.ts +14 -1
- package/dist/types/index.d.ts.map +1 -1
- package/dist/types/node/CharacterData.d.ts +0 -2
- package/dist/types/node/CharacterData.d.ts.map +1 -1
- package/dist/types/node/ChildNode.d.ts +0 -38
- package/dist/types/node/ChildNode.d.ts.map +1 -1
- package/dist/types/node/ChildNodeBase.d.ts +6 -4
- package/dist/types/node/ChildNodeBase.d.ts.map +1 -1
- package/dist/types/node/Comment.d.ts +1 -1
- package/dist/types/node/Comment.d.ts.map +1 -1
- package/dist/types/node/Document.d.ts +0 -856
- package/dist/types/node/Document.d.ts.map +1 -1
- package/dist/types/node/DocumentBase.d.ts +68 -110
- package/dist/types/node/DocumentBase.d.ts.map +1 -1
- package/dist/types/node/DocumentFragment.d.ts +0 -38
- package/dist/types/node/DocumentFragment.d.ts.map +1 -1
- package/dist/types/node/DocumentFragmentBase.d.ts +1 -8
- package/dist/types/node/DocumentFragmentBase.d.ts.map +1 -1
- package/dist/types/node/Node.d.ts +0 -213
- package/dist/types/node/Node.d.ts.map +1 -1
- package/dist/types/node/NodeBase.d.ts +11 -8
- package/dist/types/node/NodeBase.d.ts.map +1 -1
- package/dist/types/node/NodeFilter.d.ts +25 -0
- package/dist/types/node/NodeFilter.d.ts.map +1 -0
- package/dist/types/node/NodeIterator.d.ts +0 -34
- package/dist/types/node/NodeIterator.d.ts.map +1 -1
- package/dist/types/node/ParentNode.d.ts +0 -84
- package/dist/types/node/ParentNode.d.ts.map +1 -1
- package/dist/types/node/ParentNodeBase.d.ts +0 -5
- package/dist/types/node/ParentNodeBase.d.ts.map +1 -1
- package/dist/types/node/ShadowRootBase.d.ts +36 -0
- package/dist/types/node/ShadowRootBase.d.ts.map +1 -0
- package/dist/types/node/Text.d.ts +0 -24
- package/dist/types/node/Text.d.ts.map +1 -1
- package/dist/types/node/TextBase.d.ts +2 -3
- package/dist/types/node/TextBase.d.ts.map +1 -1
- package/dist/types/node/TreeWalker.d.ts +48 -0
- package/dist/types/node/TreeWalker.d.ts.map +1 -0
- package/dist/types/node/collection/{HTMLCollection.d.ts → HTMLCollectionImp.d.ts} +2 -3
- package/dist/types/node/collection/HTMLCollectionImp.d.ts.map +1 -0
- package/dist/types/node/collection/HTMLCollectionOfImp.d.ts +9 -0
- package/dist/types/node/collection/HTMLCollectionOfImp.d.ts.map +1 -0
- package/dist/types/node/collection/NodeList.d.ts +0 -1
- package/dist/types/node/collection/NodeList.d.ts.map +1 -1
- package/dist/types/node/collection/{NodeListOf.d.ts → NodeListOfImp.d.ts} +3 -4
- package/dist/types/node/collection/NodeListOfImp.d.ts.map +1 -0
- package/dist/types/node/collection/StylePropertyMapImpl.d.ts +20 -0
- package/dist/types/node/collection/StylePropertyMapImpl.d.ts.map +1 -0
- package/dist/types/node/collection/index.d.ts +3 -3
- package/dist/types/node/collection/index.d.ts.map +1 -1
- package/dist/types/node/elements/Element.d.ts +0 -687
- package/dist/types/node/elements/Element.d.ts.map +1 -1
- package/dist/types/node/elements/ElementBase.d.ts +98 -74
- package/dist/types/node/elements/ElementBase.d.ts.map +1 -1
- package/dist/types/node/elements/HTMLAnchorElement.d.ts +2 -2
- package/dist/types/node/elements/HTMLAnchorElement.d.ts.map +1 -1
- package/dist/types/node/elements/HTMLAreaElement.d.ts +2 -3
- package/dist/types/node/elements/HTMLAreaElement.d.ts.map +1 -1
- package/dist/types/node/elements/HTMLAudioElement.d.ts +8 -0
- package/dist/types/node/elements/HTMLAudioElement.d.ts.map +1 -0
- package/dist/types/node/elements/HTMLBaseElement.d.ts +2 -2
- package/dist/types/node/elements/HTMLBaseElement.d.ts.map +1 -1
- package/dist/types/node/elements/HTMLBodyElement.d.ts +2 -2
- package/dist/types/node/elements/HTMLBodyElement.d.ts.map +1 -1
- package/dist/types/node/elements/HTMLButtonElement.d.ts +3 -3
- package/dist/types/node/elements/HTMLButtonElement.d.ts.map +1 -1
- package/dist/types/node/elements/HTMLCanvasElement.d.ts +2 -2
- package/dist/types/node/elements/HTMLCanvasElement.d.ts.map +1 -1
- package/dist/types/node/elements/HTMLCaptionElement.d.ts +2 -2
- package/dist/types/node/elements/HTMLCaptionElement.d.ts.map +1 -1
- package/dist/types/node/elements/HTMLDListElement.d.ts +5 -0
- package/dist/types/node/elements/HTMLDListElement.d.ts.map +1 -0
- package/dist/types/node/elements/HTMLDataElement.d.ts +5 -0
- package/dist/types/node/elements/HTMLDataElement.d.ts.map +1 -0
- package/dist/types/node/elements/HTMLDataListElement.d.ts +5 -0
- package/dist/types/node/elements/HTMLDataListElement.d.ts.map +1 -0
- package/dist/types/node/elements/HTMLDetailsElement.d.ts +5 -0
- package/dist/types/node/elements/HTMLDetailsElement.d.ts.map +1 -0
- package/dist/types/node/elements/HTMLDialogElement.d.ts +5 -0
- package/dist/types/node/elements/HTMLDialogElement.d.ts.map +1 -0
- package/dist/types/node/elements/HTMLDivElement.d.ts +2 -2
- package/dist/types/node/elements/HTMLDivElement.d.ts.map +1 -1
- package/dist/types/node/elements/HTMLElement.d.ts +3 -119
- package/dist/types/node/elements/HTMLElement.d.ts.map +1 -1
- package/dist/types/node/elements/HTMLElementBase.d.ts +126 -5
- package/dist/types/node/elements/HTMLElementBase.d.ts.map +1 -1
- package/dist/types/node/elements/HTMLEmbedElement.d.ts +2 -3
- package/dist/types/node/elements/HTMLEmbedElement.d.ts.map +1 -1
- package/dist/types/node/elements/HTMLFieldSetElement.d.ts +5 -0
- package/dist/types/node/elements/HTMLFieldSetElement.d.ts.map +1 -0
- package/dist/types/node/elements/HTMLFormElement.d.ts +2 -2
- package/dist/types/node/elements/HTMLFormElement.d.ts.map +1 -1
- package/dist/types/node/elements/HTMLH1Element.d.ts +2 -2
- package/dist/types/node/elements/HTMLH1Element.d.ts.map +1 -1
- package/dist/types/node/elements/HTMLHRElement.d.ts +5 -0
- package/dist/types/node/elements/HTMLHRElement.d.ts.map +1 -0
- package/dist/types/node/elements/HTMLHeadElement.d.ts +2 -2
- package/dist/types/node/elements/HTMLHeadElement.d.ts.map +1 -1
- package/dist/types/node/elements/HTMLHtmlElement.d.ts +2 -2
- package/dist/types/node/elements/HTMLHtmlElement.d.ts.map +1 -1
- package/dist/types/node/elements/HTMLIFrameElement.d.ts +5 -0
- package/dist/types/node/elements/HTMLIFrameElement.d.ts.map +1 -0
- package/dist/types/node/elements/HTMLImgElement.d.ts +2 -2
- package/dist/types/node/elements/HTMLImgElement.d.ts.map +1 -1
- package/dist/types/node/elements/HTMLInputElement.d.ts +2 -2
- package/dist/types/node/elements/HTMLInputElement.d.ts.map +1 -1
- package/dist/types/node/elements/HTMLLIElement.d.ts +2 -2
- package/dist/types/node/elements/HTMLLIElement.d.ts.map +1 -1
- package/dist/types/node/elements/HTMLLabelElement.d.ts +5 -0
- package/dist/types/node/elements/HTMLLabelElement.d.ts.map +1 -0
- package/dist/types/node/elements/HTMLLegendElement.d.ts +5 -0
- package/dist/types/node/elements/HTMLLegendElement.d.ts.map +1 -0
- package/dist/types/node/elements/HTMLLinkElement.d.ts +2 -2
- package/dist/types/node/elements/HTMLLinkElement.d.ts.map +1 -1
- package/dist/types/node/elements/HTMLMapElement.d.ts +5 -0
- package/dist/types/node/elements/HTMLMapElement.d.ts.map +1 -0
- package/dist/types/node/elements/HTMLMetaElement.d.ts +2 -2
- package/dist/types/node/elements/HTMLMetaElement.d.ts.map +1 -1
- package/dist/types/node/elements/HTMLMeterElement.d.ts +5 -0
- package/dist/types/node/elements/HTMLMeterElement.d.ts.map +1 -0
- package/dist/types/node/elements/HTMLModElement.d.ts +5 -0
- package/dist/types/node/elements/HTMLModElement.d.ts.map +1 -0
- package/dist/types/node/elements/HTMLOListElement.d.ts +2 -2
- package/dist/types/node/elements/HTMLOListElement.d.ts.map +1 -1
- package/dist/types/node/elements/HTMLObjectElement.d.ts +5 -0
- package/dist/types/node/elements/HTMLObjectElement.d.ts.map +1 -0
- package/dist/types/node/elements/HTMLOptGroupElement.d.ts +5 -0
- package/dist/types/node/elements/HTMLOptGroupElement.d.ts.map +1 -0
- package/dist/types/node/elements/HTMLOptionElement.d.ts +5 -0
- package/dist/types/node/elements/HTMLOptionElement.d.ts.map +1 -0
- package/dist/types/node/elements/HTMLOutputElement.d.ts +5 -0
- package/dist/types/node/elements/HTMLOutputElement.d.ts.map +1 -0
- package/dist/types/node/elements/HTMLPElement.d.ts +2 -2
- package/dist/types/node/elements/HTMLPElement.d.ts.map +1 -1
- package/dist/types/node/elements/HTMLParamElement.d.ts +5 -0
- package/dist/types/node/elements/HTMLParamElement.d.ts.map +1 -0
- package/dist/types/node/elements/HTMLPictureElement.d.ts +5 -0
- package/dist/types/node/elements/HTMLPictureElement.d.ts.map +1 -0
- package/dist/types/node/elements/HTMLPreElement.d.ts +5 -0
- package/dist/types/node/elements/HTMLPreElement.d.ts.map +1 -0
- package/dist/types/node/elements/HTMLProgressElement.d.ts +5 -0
- package/dist/types/node/elements/HTMLProgressElement.d.ts.map +1 -0
- package/dist/types/node/elements/HTMLQuoteElement.d.ts +5 -0
- package/dist/types/node/elements/HTMLQuoteElement.d.ts.map +1 -0
- package/dist/types/node/elements/HTMLScriptElement.d.ts +2 -2
- package/dist/types/node/elements/HTMLScriptElement.d.ts.map +1 -1
- package/dist/types/node/elements/HTMLSelectElement.d.ts +5 -0
- package/dist/types/node/elements/HTMLSelectElement.d.ts.map +1 -0
- package/dist/types/node/elements/HTMLSlotElement.d.ts +5 -0
- package/dist/types/node/elements/HTMLSlotElement.d.ts.map +1 -0
- package/dist/types/node/elements/HTMLSourceElement.d.ts +5 -0
- package/dist/types/node/elements/HTMLSourceElement.d.ts.map +1 -0
- package/dist/types/node/elements/HTMLSpanElement.d.ts +2 -2
- package/dist/types/node/elements/HTMLSpanElement.d.ts.map +1 -1
- package/dist/types/node/elements/HTMLStyleElement.d.ts +2 -2
- package/dist/types/node/elements/HTMLStyleElement.d.ts.map +1 -1
- package/dist/types/node/elements/HTMLTableElement.d.ts +5 -6
- package/dist/types/node/elements/HTMLTableElement.d.ts.map +1 -1
- package/dist/types/node/elements/HTMLTbodyElement.d.ts +3 -4
- package/dist/types/node/elements/HTMLTbodyElement.d.ts.map +1 -1
- package/dist/types/node/elements/HTMLTdElement.d.ts +2 -2
- package/dist/types/node/elements/HTMLTdElement.d.ts.map +1 -1
- package/dist/types/node/elements/HTMLTemplateElement.d.ts +2 -3
- package/dist/types/node/elements/HTMLTemplateElement.d.ts.map +1 -1
- package/dist/types/node/elements/HTMLTextAreaElement.d.ts +5 -0
- package/dist/types/node/elements/HTMLTextAreaElement.d.ts.map +1 -0
- package/dist/types/node/elements/HTMLTfootElement.d.ts +4 -5
- package/dist/types/node/elements/HTMLTfootElement.d.ts.map +1 -1
- package/dist/types/node/elements/HTMLThElement.d.ts +2 -2
- package/dist/types/node/elements/HTMLThElement.d.ts.map +1 -1
- package/dist/types/node/elements/HTMLTheadElement.d.ts +4 -5
- package/dist/types/node/elements/HTMLTheadElement.d.ts.map +1 -1
- package/dist/types/node/elements/HTMLTimeElement.d.ts +5 -0
- package/dist/types/node/elements/HTMLTimeElement.d.ts.map +1 -0
- package/dist/types/node/elements/HTMLTitleElement.d.ts +2 -2
- package/dist/types/node/elements/HTMLTitleElement.d.ts.map +1 -1
- package/dist/types/node/elements/HTMLTrElement.d.ts +4 -5
- package/dist/types/node/elements/HTMLTrElement.d.ts.map +1 -1
- package/dist/types/node/elements/HTMLTrackElement.d.ts +5 -0
- package/dist/types/node/elements/HTMLTrackElement.d.ts.map +1 -0
- package/dist/types/node/elements/HTMLUListElement.d.ts +2 -2
- package/dist/types/node/elements/HTMLUListElement.d.ts.map +1 -1
- package/dist/types/node/elements/HTMLVideoElement.d.ts +8 -0
- package/dist/types/node/elements/HTMLVideoElement.d.ts.map +1 -0
- package/dist/types/node/elements/MathMLElement.d.ts +2 -2
- package/dist/types/node/elements/MathMLElement.d.ts.map +1 -1
- package/dist/types/node/elements/SVGElement.d.ts +2 -2
- package/dist/types/node/elements/SVGElement.d.ts.map +1 -1
- package/dist/types/node/elements/index.d.ts +108 -55
- package/dist/types/node/elements/index.d.ts.map +1 -1
- package/dist/types/node/index.d.ts +4 -7
- package/dist/types/node/index.d.ts.map +1 -1
- package/dist/types/utils/CSSSelector.d.ts +0 -1
- package/dist/types/utils/CSSSelector.d.ts.map +1 -1
- package/dist/types/window/CustomElementRegistryImp.d.ts +19 -0
- package/dist/types/window/CustomElementRegistryImp.d.ts.map +1 -0
- package/dist/types/window/Window.d.ts +0 -619
- package/dist/types/window/Window.d.ts.map +1 -1
- package/dist/types/window/WindowBase.d.ts +253 -286
- package/dist/types/window/WindowBase.d.ts.map +1 -1
- package/dist/types/window/index.d.ts +0 -1
- package/dist/types/window/index.d.ts.map +1 -1
- package/dist/umd-bundle/dooboostore-dom-parser.umd.js +3482 -3563
- package/dist/umd-bundle/dooboostore-dom-parser.umd.js.map +4 -4
- package/package.json +6 -1
- package/src/DomParser.ts +29 -20
- package/src/bundle-entry.ts +2 -0
- package/src/factory/ElementFactory.ts +87 -54
- package/src/index.ts +22 -10
- package/src/node/CharacterData.ts +0 -2
- package/src/node/ChildNode.ts +42 -42
- package/src/node/ChildNodeBase.ts +60 -39
- package/src/node/Comment.ts +60 -60
- package/src/node/Document.ts +129 -882
- package/src/node/DocumentBase.ts +371 -467
- package/src/node/DocumentFragment.ts +38 -44
- package/src/node/DocumentFragmentBase.ts +4 -9
- package/src/node/Node.ts +231 -224
- package/src/node/NodeBase.ts +469 -443
- package/src/node/NodeFilter.ts +50 -0
- package/src/node/NodeIterator.ts +117 -172
- package/src/node/ParentNode.ts +93 -93
- package/src/node/ParentNodeBase.ts +7 -10
- package/src/node/ShadowRootBase.ts +87 -0
- package/src/node/Text.ts +30 -30
- package/src/node/TextBase.ts +92 -94
- package/src/node/TreeWalker.ts +280 -0
- package/src/node/collection/{HTMLCollection.ts → HTMLCollectionImp.ts} +3 -2
- package/src/node/collection/HTMLCollectionOfImp.ts +12 -0
- package/src/node/collection/NodeList.ts +1 -1
- package/src/node/collection/{NodeListOf.ts → NodeListOfImp.ts} +3 -3
- package/src/node/collection/StylePropertyMapImpl.ts +60 -0
- package/src/node/collection/index.ts +3 -3
- package/src/node/elements/Element.ts +212 -772
- package/src/node/elements/ElementBase.ts +840 -1204
- package/src/node/elements/HTMLAnchorElement.ts +2 -1
- package/src/node/elements/HTMLAreaElement.ts +2 -2
- package/src/node/elements/HTMLAudioElement.ts +11 -0
- package/src/node/elements/HTMLBaseElement.ts +2 -1
- package/src/node/elements/HTMLBodyElement.ts +2 -1
- package/src/node/elements/HTMLButtonElement.ts +65 -64
- package/src/node/elements/HTMLCanvasElement.ts +2 -1
- package/src/node/elements/HTMLCaptionElement.ts +2 -1
- package/src/node/elements/HTMLDListElement.ts +8 -0
- package/src/node/elements/HTMLDataElement.ts +7 -0
- package/src/node/elements/HTMLDataListElement.ts +8 -0
- package/src/node/elements/HTMLDetailsElement.ts +8 -0
- package/src/node/elements/HTMLDialogElement.ts +8 -0
- package/src/node/elements/HTMLDivElement.ts +2 -1
- package/src/node/elements/HTMLElement.ts +6 -137
- package/src/node/elements/HTMLElementBase.ts +472 -355
- package/src/node/elements/HTMLEmbedElement.ts +2 -2
- package/src/node/elements/HTMLFieldSetElement.ts +8 -0
- package/src/node/elements/HTMLFormElement.ts +2 -1
- package/src/node/elements/HTMLH1Element.ts +2 -1
- package/src/node/elements/HTMLHRElement.ts +8 -0
- package/src/node/elements/HTMLHeadElement.ts +2 -1
- package/src/node/elements/HTMLHtmlElement.ts +2 -1
- package/src/node/elements/HTMLIFrameElement.ts +8 -0
- package/src/node/elements/HTMLImgElement.ts +2 -1
- package/src/node/elements/HTMLInputElement.ts +2 -1
- package/src/node/elements/HTMLLIElement.ts +2 -1
- package/src/node/elements/HTMLLabelElement.ts +3 -0
- package/src/node/elements/HTMLLegendElement.ts +3 -0
- package/src/node/elements/HTMLLinkElement.ts +2 -1
- package/src/node/elements/HTMLMapElement.ts +3 -0
- package/src/node/elements/HTMLMetaElement.ts +2 -1
- package/src/node/elements/HTMLMeterElement.ts +3 -0
- package/src/node/elements/HTMLModElement.ts +3 -0
- package/src/node/elements/HTMLOListElement.ts +2 -1
- package/src/node/elements/HTMLObjectElement.ts +3 -0
- package/src/node/elements/HTMLOptGroupElement.ts +3 -0
- package/src/node/elements/HTMLOptionElement.ts +3 -0
- package/src/node/elements/HTMLOutputElement.ts +3 -0
- package/src/node/elements/HTMLPElement.ts +2 -1
- package/src/node/elements/HTMLParamElement.ts +3 -0
- package/src/node/elements/HTMLPictureElement.ts +3 -0
- package/src/node/elements/HTMLPreElement.ts +3 -0
- package/src/node/elements/HTMLProgressElement.ts +3 -0
- package/src/node/elements/HTMLQuoteElement.ts +3 -0
- package/src/node/elements/HTMLScriptElement.ts +2 -1
- package/src/node/elements/HTMLSelectElement.ts +3 -0
- package/src/node/elements/HTMLSlotElement.ts +3 -0
- package/src/node/elements/HTMLSourceElement.ts +3 -0
- package/src/node/elements/HTMLSpanElement.ts +2 -1
- package/src/node/elements/HTMLStyleElement.ts +2 -1
- package/src/node/elements/HTMLTableElement.ts +5 -8
- package/src/node/elements/HTMLTbodyElement.ts +4 -4
- package/src/node/elements/HTMLTdElement.ts +3 -2
- package/src/node/elements/HTMLTemplateElement.ts +5 -7
- package/src/node/elements/HTMLTextAreaElement.ts +3 -0
- package/src/node/elements/HTMLTfootElement.ts +4 -4
- package/src/node/elements/HTMLThElement.ts +2 -1
- package/src/node/elements/HTMLTheadElement.ts +5 -5
- package/src/node/elements/HTMLTimeElement.ts +3 -0
- package/src/node/elements/HTMLTitleElement.ts +2 -1
- package/src/node/elements/HTMLTrElement.ts +7 -5
- package/src/node/elements/HTMLTrackElement.ts +3 -0
- package/src/node/elements/HTMLUListElement.ts +2 -1
- package/src/node/elements/HTMLVideoElement.ts +11 -0
- package/src/node/elements/MathMLElement.ts +2 -1
- package/src/node/elements/SVGElement.ts +2 -1
- package/src/node/elements/index.ts +231 -153
- package/src/node/index.ts +8 -8
- package/src/utils/CSSSelector.ts +0 -1
- package/src/window/CustomElementRegistryImp.ts +138 -0
- package/src/window/Window.ts +716 -715
- package/src/window/WindowBase.ts +482 -847
- package/src/window/index.ts +0 -1
- package/tsconfig.json +1 -0
- package/dist/cjs/node/collection/HTMLCollection.js.map +0 -7
- package/dist/cjs/node/collection/HTMLCollectionOf.js.map +0 -7
- package/dist/cjs/node/collection/NodeListOf.js.map +0 -7
- package/dist/cjs/node/elements/HTMLGenericElement.js.map +0 -7
- package/dist/esm/node/collection/HTMLCollection.js.map +0 -7
- package/dist/esm/node/collection/HTMLCollectionOf.js +0 -17
- package/dist/esm/node/collection/HTMLCollectionOf.js.map +0 -7
- package/dist/esm/node/collection/NodeListOf.js.map +0 -7
- package/dist/esm/node/elements/HTMLGenericElement.js +0 -13
- package/dist/esm/node/elements/HTMLGenericElement.js.map +0 -7
- package/dist/types/node/collection/HTMLCollection.d.ts.map +0 -1
- package/dist/types/node/collection/HTMLCollectionOf.d.ts +0 -14
- package/dist/types/node/collection/HTMLCollectionOf.d.ts.map +0 -1
- package/dist/types/node/collection/NodeListOf.d.ts.map +0 -1
- package/dist/types/node/elements/HTMLGenericElement.d.ts +0 -6
- package/dist/types/node/elements/HTMLGenericElement.d.ts.map +0 -1
- package/src/node/collection/HTMLCollectionOf.ts +0 -26
- package/src/node/elements/HTMLGenericElement.ts +0 -13
|
@@ -1,1248 +1,884 @@
|
|
|
1
1
|
import { ParentNodeBase } from '../ParentNodeBase';
|
|
2
|
-
import {
|
|
3
|
-
import { HTMLCollection } from "../collection";
|
|
4
|
-
import { Text } from "../Text";
|
|
5
|
-
import { ElementFactory } from "../../factory/ElementFactory";
|
|
6
|
-
import { Element, DOMTokenList, Attr, NamedNodeMap, DOMRect } from './Element';
|
|
2
|
+
import { HTMLCollectionImp, HTMLCollectionOfImp } from '../collection';
|
|
7
3
|
import { ELEMENT_NODE, TEXT_NODE, ATTRIBUTE_NODE } from '../Node';
|
|
8
4
|
import { CSSSelector } from '../../utils/CSSSelector';
|
|
9
|
-
import { HTMLElementTagNameMap } from "./index";
|
|
10
5
|
import { NodeBase } from '../NodeBase';
|
|
11
|
-
|
|
12
|
-
// InsertPosition type for insertAdjacent methods
|
|
13
|
-
type InsertPosition = 'beforebegin' | 'afterbegin' | 'beforeend' | 'afterend';
|
|
6
|
+
import { ShadowRootBase } from '../ShadowRootBase';
|
|
14
7
|
|
|
15
8
|
// Simple DOMException class for error handling
|
|
16
9
|
class DOMException extends Error {
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
10
|
+
constructor(
|
|
11
|
+
message: string,
|
|
12
|
+
public name: string = 'DOMException'
|
|
13
|
+
) {
|
|
14
|
+
super(message);
|
|
15
|
+
this.name = name;
|
|
16
|
+
}
|
|
21
17
|
}
|
|
18
|
+
|
|
22
19
|
/**
|
|
23
20
|
* Base implementation of the Element interface
|
|
24
21
|
*/
|
|
22
|
+
// @ts-ignore
|
|
25
23
|
export abstract class ElementBase extends ParentNodeBase implements Element {
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
24
|
+
/**
|
|
25
|
+
* Static dependencies to break circular references without using 'require' or 'global'.
|
|
26
|
+
* These are injected by the main DomParser entry point.
|
|
27
|
+
*/
|
|
28
|
+
public static dependencies: {
|
|
29
|
+
ElementFactory?: any;
|
|
30
|
+
TextBase?: any;
|
|
31
|
+
Comment?: any;
|
|
32
|
+
} = {};
|
|
33
|
+
|
|
34
|
+
private _id: string = '';
|
|
35
|
+
private _className: string = '';
|
|
36
|
+
private _attributes: Map<string, string> = new Map();
|
|
37
|
+
private _shadowRoot: ShadowRoot | null = null;
|
|
38
|
+
|
|
39
|
+
constructor(
|
|
40
|
+
public _tagName: string = 'DIV',
|
|
41
|
+
ownerDocument?: any
|
|
42
|
+
) {
|
|
43
|
+
super(ELEMENT_NODE, _tagName.toUpperCase(), ownerDocument);
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
ariaActiveDescendantElement: Element;
|
|
47
|
+
ariaAtomic: string;
|
|
48
|
+
ariaAutoComplete: string;
|
|
49
|
+
ariaBrailleLabel: string;
|
|
50
|
+
ariaBrailleRoleDescription: string;
|
|
51
|
+
ariaBusy: string;
|
|
52
|
+
ariaChecked: string;
|
|
53
|
+
ariaColCount: string;
|
|
54
|
+
ariaColIndex: string;
|
|
55
|
+
ariaColIndexText: string;
|
|
56
|
+
ariaColSpan: string;
|
|
57
|
+
ariaControlsElements: readonly Element[];
|
|
58
|
+
ariaCurrent: string;
|
|
59
|
+
ariaDescribedByElements: readonly Element[];
|
|
60
|
+
ariaDescription: string;
|
|
61
|
+
ariaDetailsElements: readonly Element[];
|
|
62
|
+
ariaDisabled: string;
|
|
63
|
+
ariaErrorMessageElements: readonly Element[];
|
|
64
|
+
ariaExpanded: string;
|
|
65
|
+
ariaFlowToElements: readonly Element[];
|
|
66
|
+
ariaHasPopup: string;
|
|
67
|
+
ariaHidden: string;
|
|
68
|
+
ariaInvalid: string;
|
|
69
|
+
ariaKeyShortcuts: string;
|
|
70
|
+
ariaLabel: string;
|
|
71
|
+
ariaLabelledByElements: readonly Element[];
|
|
72
|
+
ariaLevel: string;
|
|
73
|
+
ariaLive: string;
|
|
74
|
+
ariaModal: string;
|
|
75
|
+
ariaMultiLine: string;
|
|
76
|
+
ariaMultiSelectable: string;
|
|
77
|
+
ariaOrientation: string;
|
|
78
|
+
ariaOwnsElements: readonly Element[];
|
|
79
|
+
ariaPlaceholder: string;
|
|
80
|
+
ariaPosInSet: string;
|
|
81
|
+
ariaPressed: string;
|
|
82
|
+
ariaReadOnly: string;
|
|
83
|
+
ariaRelevant: string;
|
|
84
|
+
ariaRequired: string;
|
|
85
|
+
ariaRoleDescription: string;
|
|
86
|
+
ariaRowCount: string;
|
|
87
|
+
ariaRowIndex: string;
|
|
88
|
+
ariaRowIndexText: string;
|
|
89
|
+
ariaRowSpan: string;
|
|
90
|
+
ariaSelected: string;
|
|
91
|
+
ariaSetSize: string;
|
|
92
|
+
ariaSort: string;
|
|
93
|
+
ariaValueMax: string;
|
|
94
|
+
ariaValueMin: string;
|
|
95
|
+
ariaValueNow: string;
|
|
96
|
+
ariaValueText: string;
|
|
97
|
+
role: string;
|
|
98
|
+
animate(keyframes: Keyframe[] | PropertyIndexedKeyframes | null, options?: number | KeyframeAnimationOptions): Animation {
|
|
99
|
+
throw new Error('Method not implemented.');
|
|
100
|
+
}
|
|
101
|
+
getAnimations(options?: GetAnimationsOptions): Animation[] {
|
|
102
|
+
throw new Error('Method not implemented.');
|
|
103
|
+
}
|
|
104
|
+
|
|
105
|
+
get tagName(): string {
|
|
106
|
+
return this._tagName.toUpperCase();
|
|
107
|
+
}
|
|
108
|
+
|
|
109
|
+
get localName(): string {
|
|
110
|
+
return this._tagName.toLowerCase();
|
|
111
|
+
}
|
|
112
|
+
|
|
113
|
+
// Element interface implementation
|
|
114
|
+
get id(): string {
|
|
115
|
+
return this._id;
|
|
116
|
+
}
|
|
117
|
+
|
|
118
|
+
set id(value: string) {
|
|
119
|
+
this._id = value;
|
|
120
|
+
this._attributes.set('id', value);
|
|
121
|
+
}
|
|
122
|
+
|
|
123
|
+
get className(): string {
|
|
124
|
+
return this._className;
|
|
125
|
+
}
|
|
126
|
+
|
|
127
|
+
set className(value: string) {
|
|
128
|
+
this._className = value;
|
|
129
|
+
this._attributes.set('class', value);
|
|
130
|
+
}
|
|
131
|
+
|
|
132
|
+
get classList(): DOMTokenList {
|
|
133
|
+
return new (DOMTokenListImpl as any)(this);
|
|
134
|
+
}
|
|
135
|
+
|
|
136
|
+
get innerHTML(): string {
|
|
137
|
+
// Generate innerHTML from actual child nodes
|
|
138
|
+
let html = '';
|
|
139
|
+
for (const child of this._childNodesInternal) {
|
|
140
|
+
if (child.nodeType === TEXT_NODE) {
|
|
141
|
+
// For text nodes, use the escaped content stored in _nodeValue
|
|
142
|
+
html += (child as any)._nodeValue || '';
|
|
143
|
+
} else if (child.nodeType === ELEMENT_NODE) {
|
|
144
|
+
// Generate outerHTML directly to avoid circular dependency
|
|
145
|
+
html += this.generateChildElementHTML(child as any);
|
|
146
|
+
} else if (child.nodeType === 8) {
|
|
147
|
+
// COMMENT_NODE
|
|
148
|
+
html += `<!--${(child as any).textContent || ''}-->`;
|
|
149
|
+
}
|
|
150
|
+
}
|
|
151
|
+
return html;
|
|
152
|
+
}
|
|
153
|
+
|
|
154
|
+
get innerText(): string {
|
|
155
|
+
// innerText should return the decoded text content
|
|
156
|
+
return this.textContent || '';
|
|
157
|
+
}
|
|
158
|
+
|
|
159
|
+
set innerText(value: string | null) {
|
|
160
|
+
// Clear all children and add escaped text content
|
|
161
|
+
this._childNodesInternal = [];
|
|
162
|
+
if (value !== null && value !== undefined) {
|
|
163
|
+
const stringValue = String(value);
|
|
164
|
+
const escapedValue = this.escapeHTMLEntities(stringValue);
|
|
165
|
+
|
|
166
|
+
const { TextBase } = ElementBase.dependencies;
|
|
167
|
+
if (TextBase) {
|
|
168
|
+
const textNode = new TextBase(escapedValue, this._ownerDocument);
|
|
169
|
+
this._childNodesInternal.push(textNode);
|
|
170
|
+
(textNode as any)._parentNodeInternal = this;
|
|
171
|
+
}
|
|
172
|
+
}
|
|
173
|
+
}
|
|
174
|
+
|
|
175
|
+
set innerHTML(value: string) {
|
|
176
|
+
// Clear existing children
|
|
177
|
+
while (this._childNodesInternal.length > 0) {
|
|
178
|
+
const child = this._childNodesInternal[0];
|
|
179
|
+
if (child) {
|
|
180
|
+
this.removeChild(child);
|
|
181
|
+
}
|
|
182
|
+
}
|
|
183
|
+
|
|
184
|
+
// Parse HTML and create child nodes
|
|
185
|
+
if (value.trim()) {
|
|
186
|
+
this.parseAndAppendHTML(value);
|
|
187
|
+
}
|
|
188
|
+
}
|
|
189
|
+
|
|
190
|
+
/**
|
|
191
|
+
* Generate HTML for a child element without using outerHTML to avoid circular dependency
|
|
192
|
+
*/
|
|
193
|
+
private generateChildElementHTML(element: any): string {
|
|
194
|
+
const tagName = element.tagName.toLowerCase();
|
|
195
|
+
// Get attributes
|
|
196
|
+
const attrs = Array.from(element._attributes?.entries() || [])
|
|
197
|
+
.map(([name, value]: [string, string]) => (value === '' ? ` ${name}` : ` ${name}="${String(value).replace(/"/g, '"')}"`))
|
|
198
|
+
.join('');
|
|
199
|
+
|
|
200
|
+
// Check if it's a self-closing tag
|
|
201
|
+
const selfClosingTags = ['img', 'input', 'br', 'hr', 'meta', 'link', 'area', 'base', 'col', 'embed', 'source', 'track', 'wbr'];
|
|
202
|
+
const isSelfClosing = selfClosingTags.includes(tagName);
|
|
203
|
+
|
|
204
|
+
if (isSelfClosing) {
|
|
205
|
+
return `<${tagName}${attrs} />`;
|
|
206
|
+
} else {
|
|
207
|
+
// Generate innerHTML directly without calling element.innerHTML to avoid recursion
|
|
208
|
+
let childHTML = '';
|
|
209
|
+
|
|
210
|
+
// Add Declarative Shadow DOM if present
|
|
211
|
+
if (element.shadowRoot) {
|
|
212
|
+
childHTML += `<template shadowrootmode="${element.shadowRoot.mode}">${element.shadowRoot.innerHTML}</template>`;
|
|
213
|
+
}
|
|
214
|
+
|
|
215
|
+
for (const child of element._childNodesInternal || []) {
|
|
216
|
+
if (child.nodeType === TEXT_NODE) {
|
|
217
|
+
childHTML += (child as any)._nodeValue || '';
|
|
218
|
+
} else if (child.nodeType === ELEMENT_NODE) {
|
|
219
|
+
childHTML += this.generateChildElementHTML(child as any);
|
|
220
|
+
} else if (child.nodeType === 8) {
|
|
221
|
+
// COMMENT_NODE
|
|
222
|
+
childHTML += `<!--${(child as any).textContent || ''}-->`;
|
|
101
223
|
}
|
|
224
|
+
}
|
|
225
|
+
return `<${tagName}${attrs}>${childHTML}</${tagName}>`;
|
|
102
226
|
}
|
|
227
|
+
}
|
|
103
228
|
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
this.removeChild(child);
|
|
110
|
-
}
|
|
111
|
-
}
|
|
229
|
+
/**
|
|
230
|
+
* Improved HTML parser for innerHTML using a stack-based approach
|
|
231
|
+
*/
|
|
232
|
+
private parseAndAppendHTML(html: string, targetNode: any = this): void {
|
|
233
|
+
const { ElementFactory, TextBase, Comment } = ElementBase.dependencies;
|
|
112
234
|
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
235
|
+
if (!ElementFactory) {
|
|
236
|
+
// Fallback for direct library usage without entry point initialization
|
|
237
|
+
console.error('SWC DOM Parser: ElementFactory dependency not injected.');
|
|
238
|
+
return;
|
|
117
239
|
}
|
|
118
240
|
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
*/
|
|
122
|
-
private generateChildElementHTML(element: any): string {
|
|
123
|
-
const tagName = element.tagName.toLowerCase();
|
|
124
|
-
// Get attributes
|
|
125
|
-
const attrs = Array.from(element._attributes?.entries() || [])
|
|
126
|
-
.map(([name, value]: [string, string]) => value === '' ? ` ${name}` : ` ${name}="${String(value).replace(/"/g, '"')}"`)
|
|
127
|
-
.join('');
|
|
241
|
+
let i = 0;
|
|
242
|
+
const length = html.length;
|
|
128
243
|
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
const isSelfClosing = selfClosingTags.includes(tagName);
|
|
244
|
+
while (i < length) {
|
|
245
|
+
const nextTagStart = html.indexOf('<', i);
|
|
132
246
|
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
if (child.nodeType === TEXT_NODE) {
|
|
140
|
-
childHTML += (child as any)._nodeValue || '';
|
|
141
|
-
} else if (child.nodeType === ELEMENT_NODE) {
|
|
142
|
-
childHTML += this.generateChildElementHTML(child as any);
|
|
143
|
-
} else if (child.nodeType === 8) { // COMMENT_NODE
|
|
144
|
-
childHTML += `<!--${(child as any).textContent || ''}-->`;
|
|
145
|
-
}
|
|
146
|
-
}
|
|
147
|
-
return `<${tagName}${attrs}>${childHTML}</${tagName}>`;
|
|
247
|
+
// Handle text content before next tag
|
|
248
|
+
if (nextTagStart === -1) {
|
|
249
|
+
let text = html.substring(i).trim();
|
|
250
|
+
if (text) {
|
|
251
|
+
text = this.fixBrokenClosingTags(text);
|
|
252
|
+
if (TextBase) targetNode.appendChild(new TextBase(text, this._ownerDocument));
|
|
148
253
|
}
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
const ElementFactory = require('../../factory/ElementFactory').ElementFactory;
|
|
156
|
-
|
|
157
|
-
let i = 0;
|
|
158
|
-
const length = html.length;
|
|
159
|
-
|
|
160
|
-
while (i < length) {
|
|
161
|
-
const nextTagStart = html.indexOf('<', i);
|
|
162
|
-
|
|
163
|
-
// Handle text content before next tag
|
|
164
|
-
if (nextTagStart === -1) {
|
|
165
|
-
// No more tags, rest is text
|
|
166
|
-
let text = html.substring(i).trim();
|
|
167
|
-
if (text) {
|
|
168
|
-
// Fix broken closing tags (e.g., "/div>" -> "</div>")
|
|
169
|
-
text = this.fixBrokenClosingTags(text);
|
|
170
|
-
const { TextBase } = require('../TextBase');
|
|
171
|
-
const textNode = new TextBase(text, this._ownerDocument);
|
|
172
|
-
this.appendChild(textNode);
|
|
173
|
-
}
|
|
174
|
-
break;
|
|
175
|
-
} else if (nextTagStart > i) {
|
|
176
|
-
// Text content before the tag
|
|
177
|
-
let text = html.substring(i, nextTagStart).trim();
|
|
178
|
-
if (text) {
|
|
179
|
-
// Fix broken closing tags (e.g., "/div>" -> "</div>")
|
|
180
|
-
text = this.fixBrokenClosingTags(text);
|
|
181
|
-
const { TextBase } = require('../TextBase');
|
|
182
|
-
const textNode = new TextBase(text, this._ownerDocument);
|
|
183
|
-
this.appendChild(textNode);
|
|
184
|
-
}
|
|
185
|
-
}
|
|
186
|
-
|
|
187
|
-
i = nextTagStart;
|
|
188
|
-
|
|
189
|
-
// Parse the tag - find the real tag end, considering quoted attributes
|
|
190
|
-
const tagEnd = this.findTagEnd(html, i);
|
|
191
|
-
if (tagEnd === -1) break;
|
|
192
|
-
|
|
193
|
-
const tagContent = html.substring(i + 1, tagEnd);
|
|
194
|
-
|
|
195
|
-
// Handle comments
|
|
196
|
-
if (tagContent.startsWith('!--')) {
|
|
197
|
-
const commentEnd = html.indexOf('-->', i);
|
|
198
|
-
if (commentEnd !== -1) {
|
|
199
|
-
const commentContent = html.substring(i + 4, commentEnd);
|
|
200
|
-
const { Comment } = require('../Comment');
|
|
201
|
-
const commentNode = new Comment(commentContent, this._ownerDocument);
|
|
202
|
-
this.appendChild(commentNode);
|
|
203
|
-
i = commentEnd + 3;
|
|
204
|
-
continue;
|
|
205
|
-
}
|
|
206
|
-
}
|
|
207
|
-
|
|
208
|
-
// Handle self-closing tags
|
|
209
|
-
if (tagContent.endsWith('/')) {
|
|
210
|
-
const parts = tagContent.slice(0, -1).trim().split(/\s+/);
|
|
211
|
-
const tagName = parts[0];
|
|
212
|
-
const attributeString = tagContent.slice(tagName.length, -1).trim();
|
|
213
|
-
|
|
214
|
-
const element = ElementFactory.createElement(tagName, this._ownerDocument);
|
|
215
|
-
this.parseAttributes(element, attributeString);
|
|
216
|
-
this.appendChild(element);
|
|
217
|
-
i = tagEnd + 1;
|
|
218
|
-
continue;
|
|
219
|
-
}
|
|
220
|
-
|
|
221
|
-
// Handle closing tags - if they don't have matching opening tags, treat as text
|
|
222
|
-
if (tagContent.startsWith('/')) {
|
|
223
|
-
// For now, treat unmatched closing tags as text content
|
|
224
|
-
const closingTagText = `<${tagContent}>`;
|
|
225
|
-
const { TextBase } = require('../TextBase');
|
|
226
|
-
const textNode = new TextBase(closingTagText, this._ownerDocument);
|
|
227
|
-
this.appendChild(textNode);
|
|
228
|
-
i = tagEnd + 1;
|
|
229
|
-
continue;
|
|
230
|
-
}
|
|
231
|
-
|
|
232
|
-
// Handle opening tags
|
|
233
|
-
const parts = tagContent.split(/\s+/);
|
|
234
|
-
const tagName = parts[0];
|
|
235
|
-
const attributeString = tagContent.slice(tagName.length).trim();
|
|
236
|
-
|
|
237
|
-
// Special handling for style and script tags
|
|
238
|
-
if (tagName === 'style' || tagName === 'script') {
|
|
239
|
-
const closingTag = `</${tagName}>`;
|
|
240
|
-
const closingTagIndex = html.indexOf(closingTag, tagEnd + 1);
|
|
241
|
-
|
|
242
|
-
if (closingTagIndex !== -1) {
|
|
243
|
-
const element = ElementFactory.createElement(tagName, this._ownerDocument);
|
|
244
|
-
this.parseAttributes(element, attributeString);
|
|
245
|
-
|
|
246
|
-
const content = html.substring(tagEnd + 1, closingTagIndex);
|
|
247
|
-
if (content) {
|
|
248
|
-
const { TextBase } = require('../TextBase');
|
|
249
|
-
const textNode = new TextBase(content, this._ownerDocument);
|
|
250
|
-
element.appendChild(textNode);
|
|
251
|
-
}
|
|
252
|
-
|
|
253
|
-
this.appendChild(element);
|
|
254
|
-
i = closingTagIndex + closingTag.length;
|
|
255
|
-
continue;
|
|
256
|
-
}
|
|
257
|
-
}
|
|
258
|
-
|
|
259
|
-
// Handle regular opening tags with content
|
|
260
|
-
const closingTag = `</${tagName}>`;
|
|
261
|
-
const closingTagIndex = this.findMatchingClosingTag(html, tagName, tagEnd + 1);
|
|
262
|
-
|
|
263
|
-
if (closingTagIndex !== -1) {
|
|
264
|
-
const element = ElementFactory.createElement(tagName, this._ownerDocument);
|
|
265
|
-
this.parseAttributes(element, attributeString);
|
|
266
|
-
|
|
267
|
-
const content = html.substring(tagEnd + 1, closingTagIndex);
|
|
268
|
-
if (content.trim()) {
|
|
269
|
-
element.innerHTML = content;
|
|
270
|
-
}
|
|
271
|
-
|
|
272
|
-
this.appendChild(element);
|
|
273
|
-
i = closingTagIndex + closingTag.length;
|
|
274
|
-
} else {
|
|
275
|
-
// No matching closing tag found, treat as self-closing
|
|
276
|
-
const element = ElementFactory.createElement(tagName, this._ownerDocument);
|
|
277
|
-
this.parseAttributes(element, attributeString);
|
|
278
|
-
this.appendChild(element);
|
|
279
|
-
i = tagEnd + 1;
|
|
280
|
-
}
|
|
254
|
+
break;
|
|
255
|
+
} else if (nextTagStart > i) {
|
|
256
|
+
let text = html.substring(i, nextTagStart).trim();
|
|
257
|
+
if (text) {
|
|
258
|
+
text = this.fixBrokenClosingTags(text);
|
|
259
|
+
if (TextBase) targetNode.appendChild(new TextBase(text, this._ownerDocument));
|
|
281
260
|
}
|
|
282
|
-
|
|
283
|
-
|
|
284
|
-
|
|
285
|
-
|
|
286
|
-
|
|
287
|
-
|
|
288
|
-
|
|
289
|
-
|
|
290
|
-
|
|
291
|
-
|
|
292
|
-
|
|
293
|
-
|
|
294
|
-
|
|
295
|
-
|
|
296
|
-
|
|
297
|
-
|
|
298
|
-
quoteChar = char;
|
|
299
|
-
} else if (char === '>') {
|
|
300
|
-
return i;
|
|
301
|
-
}
|
|
302
|
-
} else {
|
|
303
|
-
if (char === quoteChar) {
|
|
304
|
-
inQuotes = false;
|
|
305
|
-
quoteChar = '';
|
|
306
|
-
}
|
|
307
|
-
}
|
|
308
|
-
|
|
309
|
-
i++;
|
|
261
|
+
}
|
|
262
|
+
|
|
263
|
+
i = nextTagStart;
|
|
264
|
+
const tagEnd = this.findTagEnd(html, i);
|
|
265
|
+
if (tagEnd === -1) break;
|
|
266
|
+
|
|
267
|
+
const tagContent = html.substring(i + 1, tagEnd);
|
|
268
|
+
|
|
269
|
+
// Handle comments
|
|
270
|
+
if (tagContent.startsWith('!--')) {
|
|
271
|
+
const commentEnd = html.indexOf('-->', i);
|
|
272
|
+
if (commentEnd !== -1) {
|
|
273
|
+
const commentContent = html.substring(i + 4, commentEnd);
|
|
274
|
+
if (Comment) targetNode.appendChild(new Comment(commentContent, this._ownerDocument));
|
|
275
|
+
i = commentEnd + 3;
|
|
276
|
+
continue;
|
|
310
277
|
}
|
|
311
|
-
|
|
312
|
-
|
|
313
|
-
|
|
314
|
-
|
|
315
|
-
|
|
316
|
-
|
|
317
|
-
|
|
318
|
-
|
|
319
|
-
|
|
320
|
-
|
|
321
|
-
|
|
322
|
-
|
|
323
|
-
|
|
324
|
-
|
|
325
|
-
|
|
326
|
-
|
|
327
|
-
|
|
328
|
-
|
|
329
|
-
|
|
330
|
-
|
|
331
|
-
|
|
332
|
-
|
|
333
|
-
|
|
334
|
-
|
|
335
|
-
|
|
336
|
-
|
|
337
|
-
|
|
338
|
-
|
|
339
|
-
|
|
340
|
-
|
|
341
|
-
|
|
342
|
-
|
|
343
|
-
|
|
344
|
-
|
|
345
|
-
|
|
346
|
-
|
|
347
|
-
|
|
348
|
-
|
|
349
|
-
|
|
350
|
-
|
|
351
|
-
|
|
352
|
-
|
|
353
|
-
return nextClose;
|
|
354
|
-
}
|
|
355
|
-
i = nextClose + closeTag.length;
|
|
356
|
-
}
|
|
278
|
+
}
|
|
279
|
+
|
|
280
|
+
// Handle self-closing tags
|
|
281
|
+
if (tagContent.endsWith('/')) {
|
|
282
|
+
const parts = tagContent.slice(0, -1).trim().split(/\s+/);
|
|
283
|
+
const tagName = parts[0];
|
|
284
|
+
const attributeString = tagContent.slice(tagName.length, -1).trim();
|
|
285
|
+
const element = ElementFactory.createElement(tagName, this._ownerDocument);
|
|
286
|
+
this.parseAttributes(element, attributeString);
|
|
287
|
+
targetNode.appendChild(element);
|
|
288
|
+
i = tagEnd + 1;
|
|
289
|
+
continue;
|
|
290
|
+
}
|
|
291
|
+
|
|
292
|
+
// Handle closing tags
|
|
293
|
+
if (tagContent.startsWith('/')) {
|
|
294
|
+
const closingTagText = `<${tagContent}>`;
|
|
295
|
+
if (TextBase) targetNode.appendChild(new TextBase(closingTagText, this._ownerDocument));
|
|
296
|
+
i = tagEnd + 1;
|
|
297
|
+
continue;
|
|
298
|
+
}
|
|
299
|
+
|
|
300
|
+
// Handle opening tags
|
|
301
|
+
const parts = tagContent.split(/\s+/);
|
|
302
|
+
const tagName = parts[0];
|
|
303
|
+
const attributeString = tagContent.slice(tagName.length).trim();
|
|
304
|
+
|
|
305
|
+
// Special handling for style and script tags
|
|
306
|
+
if (tagName === 'style' || tagName === 'script') {
|
|
307
|
+
const closingTag = `</${tagName}>`;
|
|
308
|
+
const closingTagIndex = html.indexOf(closingTag, tagEnd + 1);
|
|
309
|
+
|
|
310
|
+
if (closingTagIndex !== -1) {
|
|
311
|
+
const element = ElementFactory.createElement(tagName, this._ownerDocument);
|
|
312
|
+
this.parseAttributes(element, attributeString);
|
|
313
|
+
const content = html.substring(tagEnd + 1, closingTagIndex);
|
|
314
|
+
if (content && TextBase) {
|
|
315
|
+
element.appendChild(new TextBase(content, this._ownerDocument));
|
|
316
|
+
}
|
|
317
|
+
targetNode.appendChild(element);
|
|
318
|
+
i = closingTagIndex + closingTag.length;
|
|
319
|
+
continue;
|
|
357
320
|
}
|
|
321
|
+
}
|
|
358
322
|
|
|
359
|
-
|
|
360
|
-
|
|
361
|
-
|
|
362
|
-
/**
|
|
363
|
-
* Parse attributes from attribute string
|
|
364
|
-
*/
|
|
365
|
-
private parseAttributes(element: any, attributeString: string): void {
|
|
366
|
-
// Improved attribute parsing that handles complex JavaScript expressions
|
|
367
|
-
let position = 0;
|
|
368
|
-
const length = attributeString.length;
|
|
323
|
+
// Handle regular opening tags with content
|
|
324
|
+
const closingTagIndex = this.findMatchingClosingTag(html, tagName, tagEnd + 1);
|
|
369
325
|
|
|
370
|
-
|
|
371
|
-
|
|
372
|
-
|
|
373
|
-
|
|
374
|
-
|
|
375
|
-
|
|
376
|
-
if (position >= length) break;
|
|
377
|
-
|
|
378
|
-
// Find attribute name
|
|
379
|
-
const nameStart = position;
|
|
380
|
-
while (position < length && /[\w:-]/.test(attributeString[position])) {
|
|
381
|
-
position++;
|
|
382
|
-
}
|
|
383
|
-
|
|
384
|
-
if (position === nameStart) {
|
|
385
|
-
// Invalid character, skip it
|
|
386
|
-
position++;
|
|
387
|
-
continue;
|
|
388
|
-
}
|
|
389
|
-
|
|
390
|
-
const name = attributeString.substring(nameStart, position);
|
|
391
|
-
|
|
392
|
-
// Skip whitespace
|
|
393
|
-
while (position < length && /\s/.test(attributeString[position])) {
|
|
394
|
-
position++;
|
|
395
|
-
}
|
|
396
|
-
|
|
397
|
-
let value = '';
|
|
398
|
-
|
|
399
|
-
// Check if there's an equals sign
|
|
400
|
-
if (position < length && attributeString[position] === '=') {
|
|
401
|
-
position++; // Skip '='
|
|
402
|
-
|
|
403
|
-
// Skip whitespace
|
|
404
|
-
while (position < length && /\s/.test(attributeString[position])) {
|
|
405
|
-
position++;
|
|
406
|
-
}
|
|
407
|
-
|
|
408
|
-
if (position < length) {
|
|
409
|
-
const quote = attributeString[position];
|
|
410
|
-
|
|
411
|
-
if (quote === '"' || quote === "'") {
|
|
412
|
-
// Quoted value - find matching closing quote
|
|
413
|
-
position++; // Skip opening quote
|
|
414
|
-
const valueStart = position;
|
|
415
|
-
|
|
416
|
-
while (position < length && attributeString[position] !== quote) {
|
|
417
|
-
position++;
|
|
418
|
-
}
|
|
419
|
-
|
|
420
|
-
value = attributeString.substring(valueStart, position);
|
|
421
|
-
|
|
422
|
-
if (position < length && attributeString[position] === quote) {
|
|
423
|
-
position++; // Skip closing quote
|
|
424
|
-
}
|
|
425
|
-
} else {
|
|
426
|
-
// Unquoted value - read until whitespace or end
|
|
427
|
-
const valueStart = position;
|
|
428
|
-
while (position < length && !/\s/.test(attributeString[position])) {
|
|
429
|
-
position++;
|
|
430
|
-
}
|
|
431
|
-
value = attributeString.substring(valueStart, position);
|
|
432
|
-
}
|
|
433
|
-
}
|
|
434
|
-
}
|
|
435
|
-
|
|
436
|
-
// Decode HTML entities in attribute values
|
|
437
|
-
value = this.decodeHTMLEntities(value);
|
|
438
|
-
|
|
439
|
-
element.setAttribute(name, value);
|
|
326
|
+
if (closingTagIndex !== -1) {
|
|
327
|
+
const element = ElementFactory.createElement(tagName, this._ownerDocument);
|
|
328
|
+
this.parseAttributes(element, attributeString);
|
|
329
|
+
const content = html.substring(tagEnd + 1, closingTagIndex);
|
|
330
|
+
if (content.trim()) {
|
|
331
|
+
element.innerHTML = content;
|
|
440
332
|
}
|
|
441
|
-
|
|
442
|
-
|
|
443
|
-
|
|
444
|
-
|
|
445
|
-
|
|
446
|
-
|
|
447
|
-
|
|
448
|
-
|
|
449
|
-
|
|
450
|
-
|
|
451
|
-
|
|
452
|
-
|
|
453
|
-
|
|
454
|
-
|
|
455
|
-
|
|
456
|
-
|
|
457
|
-
|
|
458
|
-
|
|
459
|
-
|
|
460
|
-
|
|
461
|
-
|
|
462
|
-
|
|
463
|
-
|
|
464
|
-
|
|
465
|
-
|
|
466
|
-
|
|
467
|
-
'>': '>',
|
|
468
|
-
'"': '"',
|
|
469
|
-
''': "'",
|
|
470
|
-
'"': '"',
|
|
471
|
-
''': "'",
|
|
472
|
-
'©': '©',
|
|
473
|
-
'®': '®',
|
|
474
|
-
'™': '™',
|
|
475
|
-
' ': ' ',
|
|
476
|
-
'…': '…',
|
|
477
|
-
'—': '—',
|
|
478
|
-
'–': '–',
|
|
479
|
-
'‘': '\u2018',
|
|
480
|
-
'’': '\u2019',
|
|
481
|
-
'“': '"',
|
|
482
|
-
'”': '"'
|
|
483
|
-
};
|
|
484
|
-
|
|
485
|
-
return str.replace(/&[a-zA-Z0-9#]+;/g, (entity) => {
|
|
486
|
-
// Handle named entities
|
|
487
|
-
if (entityMap[entity]) {
|
|
488
|
-
return entityMap[entity];
|
|
489
|
-
}
|
|
490
|
-
|
|
491
|
-
// Handle numeric entities like ' "
|
|
492
|
-
if (entity.startsWith('&#') && entity.endsWith(';')) {
|
|
493
|
-
const numStr = entity.slice(2, -1);
|
|
494
|
-
const num = parseInt(numStr, 10);
|
|
495
|
-
if (!isNaN(num)) {
|
|
496
|
-
return String.fromCharCode(num);
|
|
497
|
-
}
|
|
498
|
-
}
|
|
499
|
-
|
|
500
|
-
// Handle hex entities like '
|
|
501
|
-
if (entity.startsWith('&#x') && entity.endsWith(';')) {
|
|
502
|
-
const hexStr = entity.slice(3, -1);
|
|
503
|
-
const num = parseInt(hexStr, 16);
|
|
504
|
-
if (!isNaN(num)) {
|
|
505
|
-
return String.fromCharCode(num);
|
|
506
|
-
}
|
|
507
|
-
}
|
|
508
|
-
|
|
509
|
-
// Return original if not recognized
|
|
510
|
-
return entity;
|
|
511
|
-
});
|
|
512
|
-
}
|
|
513
|
-
|
|
514
|
-
get outerHTML(): string {
|
|
515
|
-
const attrs = Array.from(this._attributes.entries())
|
|
516
|
-
.map(([name, value]) => value === '' ? ` ${name}` : ` ${name}="${value.replace(/"/g, '"')}"`)
|
|
517
|
-
.join('');
|
|
518
|
-
|
|
519
|
-
// Check if it's a self-closing tag
|
|
520
|
-
const selfClosingTags = ['img', 'input', 'br', 'hr', 'meta', 'link', 'area', 'base', 'col', 'embed', 'source', 'track', 'wbr'];
|
|
521
|
-
const isSelfClosing = selfClosingTags.includes(this.tagName.toLowerCase());
|
|
522
|
-
|
|
523
|
-
if (isSelfClosing) {
|
|
524
|
-
return `<${this.tagName.toLowerCase()}${attrs} />`;
|
|
525
|
-
} else {
|
|
526
|
-
return `<${this.tagName.toLowerCase()}${attrs}>${this.innerHTML}</${this.tagName.toLowerCase()}>`;
|
|
333
|
+
targetNode.appendChild(element);
|
|
334
|
+
i = closingTagIndex + (tagName.length + 3); // </tagName>
|
|
335
|
+
} else {
|
|
336
|
+
const element = ElementFactory.createElement(tagName, this._ownerDocument);
|
|
337
|
+
this.parseAttributes(element, attributeString);
|
|
338
|
+
targetNode.appendChild(element);
|
|
339
|
+
i = tagEnd + 1;
|
|
340
|
+
}
|
|
341
|
+
}
|
|
342
|
+
}
|
|
343
|
+
|
|
344
|
+
private findTagEnd(html: string, startIndex: number): number {
|
|
345
|
+
let i = startIndex + 1;
|
|
346
|
+
let inQuotes = false;
|
|
347
|
+
let quoteChar = '';
|
|
348
|
+
while (i < html.length) {
|
|
349
|
+
const char = html[i];
|
|
350
|
+
if (!inQuotes) {
|
|
351
|
+
if (char === '"' || char === "'") {
|
|
352
|
+
inQuotes = true;
|
|
353
|
+
quoteChar = char;
|
|
354
|
+
} else if (char === '>') return i;
|
|
355
|
+
} else {
|
|
356
|
+
if (char === quoteChar) {
|
|
357
|
+
inQuotes = false;
|
|
358
|
+
quoteChar = '';
|
|
527
359
|
}
|
|
528
|
-
|
|
529
|
-
|
|
530
|
-
|
|
531
|
-
|
|
532
|
-
|
|
533
|
-
|
|
534
|
-
|
|
535
|
-
|
|
536
|
-
|
|
537
|
-
|
|
538
|
-
|
|
539
|
-
|
|
540
|
-
|
|
541
|
-
|
|
542
|
-
|
|
543
|
-
|
|
544
|
-
|
|
545
|
-
|
|
546
|
-
|
|
547
|
-
|
|
548
|
-
|
|
549
|
-
if (
|
|
550
|
-
|
|
551
|
-
|
|
552
|
-
|
|
360
|
+
}
|
|
361
|
+
i++;
|
|
362
|
+
}
|
|
363
|
+
return -1;
|
|
364
|
+
}
|
|
365
|
+
|
|
366
|
+
private fixBrokenClosingTags(text: string): string {
|
|
367
|
+
return text.replace(/\/(\w+)>/g, '</$1>');
|
|
368
|
+
}
|
|
369
|
+
|
|
370
|
+
private findMatchingClosingTag(html: string, tagName: string, startIndex: number): number {
|
|
371
|
+
const openTag = `<${tagName}`;
|
|
372
|
+
const closeTag = `</${tagName}>`;
|
|
373
|
+
let depth = 1;
|
|
374
|
+
let i = startIndex;
|
|
375
|
+
while (i < html.length && depth > 0) {
|
|
376
|
+
const nextOpen = html.indexOf(openTag, i);
|
|
377
|
+
const nextClose = html.indexOf(closeTag, i);
|
|
378
|
+
if (nextClose === -1) return -1;
|
|
379
|
+
if (nextOpen !== -1 && nextOpen < nextClose) {
|
|
380
|
+
const afterTag = html.charAt(nextOpen + openTag.length);
|
|
381
|
+
if (afterTag === ' ' || afterTag === '>' || afterTag === '/') depth++;
|
|
382
|
+
i = nextOpen + openTag.length;
|
|
383
|
+
} else {
|
|
384
|
+
depth--;
|
|
385
|
+
if (depth === 0) return nextClose;
|
|
386
|
+
i = nextClose + closeTag.length;
|
|
387
|
+
}
|
|
388
|
+
}
|
|
389
|
+
return -1;
|
|
390
|
+
}
|
|
391
|
+
|
|
392
|
+
private parseAttributes(element: any, attributeString: string): void {
|
|
393
|
+
let position = 0;
|
|
394
|
+
const length = attributeString.length;
|
|
395
|
+
while (position < length) {
|
|
396
|
+
while (position < length && /\s/.test(attributeString[position])) position++;
|
|
397
|
+
if (position >= length) break;
|
|
398
|
+
const nameStart = position;
|
|
399
|
+
while (position < length && /[\w:-]/.test(attributeString[position])) position++;
|
|
400
|
+
if (position === nameStart) {
|
|
401
|
+
position++;
|
|
402
|
+
continue;
|
|
403
|
+
}
|
|
404
|
+
const name = attributeString.substring(nameStart, position);
|
|
405
|
+
while (position < length && /\s/.test(attributeString[position])) position++;
|
|
406
|
+
let value = '';
|
|
407
|
+
if (position < length && attributeString[position] === '=') {
|
|
408
|
+
position++;
|
|
409
|
+
while (position < length && /\s/.test(attributeString[position])) position++;
|
|
410
|
+
if (position < length) {
|
|
411
|
+
const quote = attributeString[position];
|
|
412
|
+
if (quote === '"' || quote === "'") {
|
|
413
|
+
position++;
|
|
414
|
+
const valueStart = position;
|
|
415
|
+
while (position < length && attributeString[position] !== quote) position++;
|
|
416
|
+
value = attributeString.substring(valueStart, position);
|
|
417
|
+
if (position < length && attributeString[position] === quote) position++;
|
|
418
|
+
} else {
|
|
419
|
+
const valueStart = position;
|
|
420
|
+
while (position < length && !/\s/.test(attributeString[position])) position++;
|
|
421
|
+
value = attributeString.substring(valueStart, position);
|
|
422
|
+
}
|
|
553
423
|
}
|
|
554
|
-
|
|
555
|
-
|
|
556
|
-
|
|
557
|
-
|
|
558
|
-
|
|
559
|
-
|
|
560
|
-
|
|
561
|
-
|
|
562
|
-
|
|
563
|
-
|
|
564
|
-
|
|
424
|
+
}
|
|
425
|
+
element.setAttribute(name, this.decodeHTMLEntities(value));
|
|
426
|
+
}
|
|
427
|
+
}
|
|
428
|
+
|
|
429
|
+
protected escapeHTMLEntities(str: string): string {
|
|
430
|
+
const entityMap: any = { '&': '&', '<': '<', '>': '>', '"': '"', "'": ''' };
|
|
431
|
+
return str.replace(/[&<>"']/g, char => entityMap[char] || char);
|
|
432
|
+
}
|
|
433
|
+
|
|
434
|
+
protected decodeHTMLEntities(str: string): string {
|
|
435
|
+
const entityMap: any = { '&': '&', '<': '<', '>': '>', '"': '"', ''': "'", '"': '"', ''': "'", '©': '©', '®': '®', '™': '™', ' ': ' ', '…': '…', '—': '—', '–': '–', '‘': '\u2018', '’': '\u2019', '“': '"', '”': '"' };
|
|
436
|
+
return str.replace(/&[a-zA-Z0-9#]+;/g, entity => {
|
|
437
|
+
if (entityMap[entity]) return entityMap[entity];
|
|
438
|
+
if (entity.startsWith('&#') && entity.endsWith(';')) {
|
|
439
|
+
const num = parseInt(entity.slice(2, -1), 10);
|
|
440
|
+
return isNaN(num) ? entity : String.fromCharCode(num);
|
|
441
|
+
}
|
|
442
|
+
if (entity.startsWith('&#x') && entity.endsWith(';')) {
|
|
443
|
+
const num = parseInt(entity.slice(3, -1), 16);
|
|
444
|
+
return isNaN(num) ? entity : String.fromCharCode(num);
|
|
445
|
+
}
|
|
446
|
+
return entity;
|
|
447
|
+
});
|
|
448
|
+
}
|
|
449
|
+
|
|
450
|
+
get outerHTML(): string {
|
|
451
|
+
const attrs = Array.from(this._attributes.entries())
|
|
452
|
+
.map(([name, value]) => (value === '' ? ` ${name}` : ` ${name}="${value.replace(/"/g, '"')}"`))
|
|
453
|
+
.join('');
|
|
454
|
+
const selfClosingTags = ['img', 'input', 'br', 'hr', 'meta', 'link', 'area', 'base', 'col', 'embed', 'source', 'track', 'wbr'];
|
|
455
|
+
const isSelfClosing = selfClosingTags.includes(this.tagName.toLowerCase());
|
|
456
|
+
return isSelfClosing ? `<${this.tagName.toLowerCase()}${attrs} />` : `<${this.tagName.toLowerCase()}${attrs}>${this.innerHTML}</${this.tagName.toLowerCase()}>`;
|
|
457
|
+
}
|
|
458
|
+
|
|
459
|
+
get namespaceURI(): string | null {
|
|
460
|
+
return 'http://www.w3.org/1999/xhtml';
|
|
461
|
+
}
|
|
462
|
+
get prefix(): string | null {
|
|
463
|
+
return null;
|
|
464
|
+
}
|
|
465
|
+
getAttribute(qualifiedName: string): string | null {
|
|
466
|
+
return this._attributes.get(qualifiedName.toLowerCase()) ?? null;
|
|
467
|
+
}
|
|
468
|
+
setAttribute(qualifiedName: string, value: string): void {
|
|
469
|
+
const name = qualifiedName.toLowerCase();
|
|
470
|
+
this._attributes.set(name, value);
|
|
471
|
+
if (name === 'id') this._id = value;
|
|
472
|
+
else if (name === 'class') this._className = value;
|
|
473
|
+
}
|
|
474
|
+
removeAttribute(qualifiedName: string): void {
|
|
475
|
+
const name = qualifiedName.toLowerCase();
|
|
476
|
+
this._attributes.delete(name);
|
|
477
|
+
if (name === 'id') this._id = '';
|
|
478
|
+
else if (name === 'class') this._className = '';
|
|
479
|
+
}
|
|
480
|
+
hasAttribute(qualifiedName: string): boolean {
|
|
481
|
+
return this._attributes.has(qualifiedName.toLowerCase());
|
|
482
|
+
}
|
|
483
|
+
closest(selectors: string): any {
|
|
484
|
+
let element: Element | null = this as any;
|
|
485
|
+
while (element) {
|
|
486
|
+
if (element.matches && element.matches(selectors)) return element;
|
|
487
|
+
element = element.parentElement;
|
|
488
|
+
}
|
|
489
|
+
return null;
|
|
490
|
+
}
|
|
491
|
+
matches(selectors: string): boolean {
|
|
492
|
+
return CSSSelector.matches(this as any, selectors);
|
|
493
|
+
}
|
|
494
|
+
get attributes(): any {
|
|
495
|
+
return new (NamedNodeMapImpl as any)(this._attributes);
|
|
496
|
+
}
|
|
497
|
+
get clientHeight(): number {
|
|
498
|
+
return 0;
|
|
499
|
+
}
|
|
500
|
+
get clientLeft(): number {
|
|
501
|
+
return 0;
|
|
502
|
+
}
|
|
503
|
+
get clientTop(): number {
|
|
504
|
+
return 0;
|
|
505
|
+
}
|
|
506
|
+
get clientWidth(): number {
|
|
507
|
+
return 0;
|
|
508
|
+
}
|
|
509
|
+
get currentCSSZoom(): number {
|
|
510
|
+
return 1;
|
|
511
|
+
}
|
|
512
|
+
onfullscreenchange: any = null;
|
|
513
|
+
onfullscreenerror: any = null;
|
|
514
|
+
get part(): any {
|
|
515
|
+
return { length: 0, value: '', add: () => {}, remove: () => {}, contains: () => false, toggle: () => false, replace: () => false, item: () => null };
|
|
516
|
+
}
|
|
517
|
+
get scrollHeight(): number {
|
|
518
|
+
return 0;
|
|
519
|
+
}
|
|
520
|
+
get scrollLeft(): number {
|
|
521
|
+
return 0;
|
|
522
|
+
}
|
|
523
|
+
set scrollLeft(_: number) {}
|
|
524
|
+
get scrollTop(): number {
|
|
525
|
+
return 0;
|
|
526
|
+
}
|
|
527
|
+
set scrollTop(_: number) {}
|
|
528
|
+
get scrollWidth(): number {
|
|
529
|
+
return 0;
|
|
530
|
+
}
|
|
531
|
+
get shadowRoot(): ShadowRoot | null {
|
|
532
|
+
return this._shadowRoot;
|
|
533
|
+
}
|
|
534
|
+
get slot(): string {
|
|
535
|
+
return this.getAttribute('slot') || '';
|
|
536
|
+
}
|
|
537
|
+
set slot(value: string) {
|
|
538
|
+
this.setAttribute('slot', value);
|
|
539
|
+
}
|
|
540
|
+
attachShadow(init: ShadowRootInit): ShadowRoot {
|
|
541
|
+
if (this._shadowRoot) throw new DOMException('Shadow root already attached', 'NotSupportedError');
|
|
542
|
+
this._shadowRoot = new ShadowRootBase(this as any, init, this._ownerDocument) as unknown as ShadowRoot;
|
|
543
|
+
return this._shadowRoot;
|
|
544
|
+
}
|
|
545
|
+
checkVisibility(_options?: any): boolean {
|
|
546
|
+
return true;
|
|
547
|
+
}
|
|
548
|
+
computedStyleMap(): any {
|
|
549
|
+
return new Map();
|
|
550
|
+
}
|
|
551
|
+
getAttributeNS(_ns: string | null, localName: string): string | null {
|
|
552
|
+
return this.getAttribute(localName);
|
|
553
|
+
}
|
|
554
|
+
getAttributeNames(): string[] {
|
|
555
|
+
return Array.from(this._attributes.keys());
|
|
556
|
+
}
|
|
557
|
+
getAttributeNode(qualifiedName: string): any {
|
|
558
|
+
const value = this.getAttribute(qualifiedName);
|
|
559
|
+
return value !== null ? new AttrImpl(qualifiedName, value) : null;
|
|
560
|
+
}
|
|
561
|
+
getAttributeNodeNS(_ns: string | null, localName: string): any {
|
|
562
|
+
return this.getAttributeNode(localName);
|
|
563
|
+
}
|
|
564
|
+
getBoundingClientRect(): any {
|
|
565
|
+
return { bottom: 0, height: 0, left: 0, right: 0, top: 0, width: 0, x: 0, y: 0, toJSON: () => ({}) };
|
|
566
|
+
}
|
|
567
|
+
getClientRects(): any {
|
|
568
|
+
return { length: 0, item: () => null, [Symbol.iterator]: function* () {} };
|
|
569
|
+
}
|
|
570
|
+
|
|
571
|
+
getElementsByClassName(classNames: string): HTMLCollectionOf<Element> {
|
|
572
|
+
const result: Element[] = [];
|
|
573
|
+
const classNameList = classNames.trim().split(/\s+/);
|
|
574
|
+
const hasAllClasses = (element: Element, classes: string[]): boolean => {
|
|
575
|
+
const elementClasses = element.className.trim().split(/\s+/);
|
|
576
|
+
return classes.every(cls => elementClasses.includes(cls));
|
|
577
|
+
};
|
|
578
|
+
const traverse = (node: any) => {
|
|
579
|
+
if (node.nodeType === ELEMENT_NODE && hasAllClasses(node as Element, classNameList)) result.push(node as Element);
|
|
580
|
+
for (let i = 0; i < node.childNodes.length; i++) traverse(node.childNodes[i]);
|
|
581
|
+
};
|
|
582
|
+
for (let i = 0; i < this.childNodes.length; i++) traverse(this.childNodes[i]);
|
|
583
|
+
// @ts-ignore
|
|
584
|
+
return new HTMLCollectionOfImp(result);
|
|
585
|
+
}
|
|
586
|
+
|
|
587
|
+
getElementsByTagName(qualifiedName: string): HTMLCollection {
|
|
588
|
+
const result: Element[] = [];
|
|
589
|
+
const tagName = qualifiedName.toLowerCase();
|
|
590
|
+
const isWildcard = tagName === '*';
|
|
591
|
+
const traverse = (node: any) => {
|
|
592
|
+
if (node.nodeType === ELEMENT_NODE && (isWildcard || node.localName === tagName)) result.push(node as Element);
|
|
593
|
+
for (let i = 0; i < node.childNodes.length; i++) traverse(node.childNodes[i]);
|
|
594
|
+
};
|
|
595
|
+
for (let i = 0; i < this.childNodes.length; i++) traverse(this.childNodes[i]);
|
|
596
|
+
// @ts-ignore
|
|
597
|
+
return new HTMLCollectionImp(result);
|
|
598
|
+
}
|
|
599
|
+
getElementsByTagNameNS(_ns: string | null, localName: string): any {
|
|
600
|
+
return this.getElementsByTagName(localName);
|
|
601
|
+
}
|
|
602
|
+
getHTML(_options?: any): string {
|
|
603
|
+
return this.outerHTML;
|
|
604
|
+
}
|
|
605
|
+
hasAttributeNS(_ns: string | null, localName: string): boolean {
|
|
606
|
+
return this.hasAttribute(localName);
|
|
607
|
+
}
|
|
608
|
+
hasAttributes(): boolean {
|
|
609
|
+
return this._attributes.size > 0;
|
|
610
|
+
}
|
|
611
|
+
hasPointerCapture(_id: number): boolean {
|
|
612
|
+
return false;
|
|
613
|
+
}
|
|
614
|
+
insertAdjacentElement(where: InsertPosition, element: Element): Element | null {
|
|
615
|
+
const position = where.toLowerCase();
|
|
616
|
+
switch (position) {
|
|
617
|
+
case 'beforebegin':
|
|
618
|
+
if (this.parentNode) {
|
|
619
|
+
this.parentNode.insertBefore(element as any, this as any);
|
|
620
|
+
return element;
|
|
565
621
|
}
|
|
566
|
-
}
|
|
567
|
-
|
|
568
|
-
hasAttribute(qualifiedName: string): boolean {
|
|
569
|
-
return this._attributes.has(qualifiedName.toLowerCase());
|
|
570
|
-
}
|
|
571
|
-
|
|
572
|
-
/**
|
|
573
|
-
* Returns the closest ancestor element (including the element itself) that matches the specified CSS selector.
|
|
574
|
-
*
|
|
575
|
-
* [MDN Reference](https://developer.mozilla.org/docs/Web/API/Element/closest)
|
|
576
|
-
*/
|
|
577
|
-
closest<K extends keyof HTMLElementTagNameMap>(selector: K): HTMLElementTagNameMap[K] | null;
|
|
578
|
-
closest<K extends keyof SVGElementTagNameMap>(selector: K): SVGElementTagNameMap[K] | null;
|
|
579
|
-
closest<K extends keyof MathMLElementTagNameMap>(selector: K): MathMLElementTagNameMap[K] | null;
|
|
580
|
-
closest<E extends Element = Element>(selectors: string): E | null;
|
|
581
|
-
closest(selectors: string): Element | null {
|
|
582
|
-
let element: Element | null = this as any;
|
|
583
|
-
|
|
584
|
-
while (element) {
|
|
585
|
-
if (element.matches && element.matches(selectors)) {
|
|
586
|
-
return element;
|
|
587
|
-
}
|
|
588
|
-
element = element.parentElement;
|
|
589
|
-
}
|
|
590
|
-
|
|
591
622
|
return null;
|
|
592
|
-
|
|
593
|
-
|
|
594
|
-
|
|
595
|
-
|
|
596
|
-
|
|
597
|
-
|
|
598
|
-
|
|
599
|
-
|
|
600
|
-
|
|
601
|
-
|
|
602
|
-
|
|
603
|
-
|
|
604
|
-
|
|
605
|
-
// Additional Element properties and methods - Not implemented yet
|
|
606
|
-
|
|
607
|
-
get attributes(): NamedNodeMap {
|
|
608
|
-
return new NamedNodeMapImpl(this._attributes);
|
|
609
|
-
}
|
|
610
|
-
|
|
611
|
-
get clientHeight(): number {
|
|
612
|
-
throw new Error('Element.clientHeight is not implemented yet');
|
|
613
|
-
}
|
|
614
|
-
|
|
615
|
-
get clientLeft(): number {
|
|
616
|
-
throw new Error('Element.clientLeft is not implemented yet');
|
|
617
|
-
}
|
|
618
|
-
|
|
619
|
-
get clientTop(): number {
|
|
620
|
-
throw new Error('Element.clientTop is not implemented yet');
|
|
621
|
-
}
|
|
622
|
-
|
|
623
|
-
get clientWidth(): number {
|
|
624
|
-
throw new Error('Element.clientWidth is not implemented yet');
|
|
625
|
-
}
|
|
626
|
-
|
|
627
|
-
get currentCSSZoom(): number {
|
|
628
|
-
throw new Error('Element.currentCSSZoom is not implemented yet');
|
|
629
|
-
}
|
|
630
|
-
|
|
631
|
-
onfullscreenchange: ((this: Element, ev: Event) => any) | null = null;
|
|
632
|
-
onfullscreenerror: ((this: Element, ev: Event) => any) | null = null;
|
|
633
|
-
|
|
634
|
-
get part(): any {
|
|
635
|
-
throw new Error('Element.part is not implemented yet');
|
|
636
|
-
}
|
|
637
|
-
|
|
638
|
-
get scrollHeight(): number {
|
|
639
|
-
throw new Error('Element.scrollHeight is not implemented yet');
|
|
640
|
-
}
|
|
641
|
-
|
|
642
|
-
get scrollLeft(): number {
|
|
643
|
-
throw new Error('Element.scrollLeft is not implemented yet');
|
|
644
|
-
}
|
|
645
|
-
|
|
646
|
-
set scrollLeft(value: number) {
|
|
647
|
-
throw new Error('Element.scrollLeft setter is not implemented yet');
|
|
648
|
-
}
|
|
649
|
-
|
|
650
|
-
get scrollTop(): number {
|
|
651
|
-
throw new Error('Element.scrollTop is not implemented yet');
|
|
652
|
-
}
|
|
653
|
-
|
|
654
|
-
set scrollTop(value: number) {
|
|
655
|
-
throw new Error('Element.scrollTop setter is not implemented yet');
|
|
656
|
-
}
|
|
657
|
-
|
|
658
|
-
get scrollWidth(): number {
|
|
659
|
-
throw new Error('Element.scrollWidth is not implemented yet');
|
|
660
|
-
}
|
|
661
|
-
|
|
662
|
-
get shadowRoot(): any {
|
|
663
|
-
throw new Error('Element.shadowRoot is not implemented yet');
|
|
664
|
-
}
|
|
665
|
-
|
|
666
|
-
get slot(): string {
|
|
667
|
-
throw new Error('Element.slot is not implemented yet');
|
|
668
|
-
}
|
|
669
|
-
|
|
670
|
-
set slot(value: string) {
|
|
671
|
-
throw new Error('Element.slot setter is not implemented yet');
|
|
672
|
-
}
|
|
673
|
-
|
|
674
|
-
// Methods - Not implemented yet
|
|
675
|
-
|
|
676
|
-
attachShadow(init: any): any {
|
|
677
|
-
throw new Error('Element.attachShadow() is not implemented yet');
|
|
678
|
-
}
|
|
679
|
-
|
|
680
|
-
checkVisibility(options?: any): boolean {
|
|
681
|
-
throw new Error('Element.checkVisibility() is not implemented yet');
|
|
682
|
-
}
|
|
683
|
-
|
|
684
|
-
computedStyleMap(): any {
|
|
685
|
-
throw new Error('Element.computedStyleMap() is not implemented yet');
|
|
686
|
-
}
|
|
687
|
-
|
|
688
|
-
getAttributeNS(namespace: string | null, localName: string): string | null {
|
|
689
|
-
// For simplicity, we'll ignore namespace and use localName
|
|
690
|
-
return this.getAttribute(localName);
|
|
691
|
-
}
|
|
692
|
-
|
|
693
|
-
getAttributeNames(): string[] {
|
|
694
|
-
return Array.from(this._attributes.keys());
|
|
695
|
-
}
|
|
696
|
-
|
|
697
|
-
getAttributeNode(qualifiedName: string): Attr | null {
|
|
698
|
-
const value = this.getAttribute(qualifiedName);
|
|
699
|
-
if (value !== null) {
|
|
700
|
-
return new AttrImpl(qualifiedName, value);
|
|
623
|
+
case 'afterbegin':
|
|
624
|
+
if (this.firstChild) this.insertBefore(element as any, this.firstChild);
|
|
625
|
+
else this.appendChild(element as any);
|
|
626
|
+
return element;
|
|
627
|
+
case 'beforeend':
|
|
628
|
+
this.appendChild(element as any);
|
|
629
|
+
return element;
|
|
630
|
+
case 'afterend':
|
|
631
|
+
if (this.parentNode) {
|
|
632
|
+
if (this.nextSibling) this.parentNode.insertBefore(element as any, this.nextSibling);
|
|
633
|
+
else this.parentNode.appendChild(element as any);
|
|
634
|
+
return element;
|
|
701
635
|
}
|
|
702
636
|
return null;
|
|
703
|
-
|
|
704
|
-
|
|
705
|
-
|
|
706
|
-
|
|
707
|
-
|
|
708
|
-
|
|
709
|
-
|
|
710
|
-
|
|
711
|
-
|
|
712
|
-
|
|
713
|
-
|
|
714
|
-
|
|
715
|
-
|
|
716
|
-
|
|
717
|
-
|
|
718
|
-
|
|
719
|
-
|
|
720
|
-
|
|
721
|
-
|
|
722
|
-
|
|
723
|
-
|
|
724
|
-
|
|
725
|
-
|
|
726
|
-
|
|
727
|
-
|
|
728
|
-
getElementsByClassName(classNames: string): HTMLCollection {
|
|
729
|
-
const result: Element[] = [];
|
|
730
|
-
const classNameList = classNames.trim().split(/\s+/);
|
|
731
|
-
|
|
732
|
-
// Helper function to check if element has all specified classes
|
|
733
|
-
const hasAllClasses = (element: Element, classes: string[]): boolean => {
|
|
734
|
-
const elementClasses = element.className.trim().split(/\s+/);
|
|
735
|
-
return classes.every(cls => elementClasses.includes(cls));
|
|
736
|
-
};
|
|
737
|
-
|
|
738
|
-
// Recursive function to traverse all descendants
|
|
739
|
-
const traverse = (node: any) => {
|
|
740
|
-
if (node.nodeType === ELEMENT_NODE) {
|
|
741
|
-
const element = node as Element;
|
|
742
|
-
if (hasAllClasses(element, classNameList)) {
|
|
743
|
-
result.push(element);
|
|
744
|
-
}
|
|
745
|
-
}
|
|
746
|
-
|
|
747
|
-
// Traverse children
|
|
748
|
-
for (let i = 0; i < node.childNodes.length; i++) {
|
|
749
|
-
traverse(node.childNodes[i]);
|
|
750
|
-
}
|
|
751
|
-
};
|
|
752
|
-
|
|
753
|
-
// Start traversal from this element's children
|
|
754
|
-
for (let i = 0; i < this.childNodes.length; i++) {
|
|
755
|
-
traverse(this.childNodes[i]);
|
|
756
|
-
}
|
|
757
|
-
|
|
758
|
-
return new HTMLCollection(result);
|
|
759
|
-
}
|
|
760
|
-
|
|
761
|
-
getElementsByTagName(qualifiedName: string): HTMLCollection {
|
|
762
|
-
const result: Element[] = [];
|
|
763
|
-
const tagName = qualifiedName.toLowerCase();
|
|
764
|
-
const isWildcard = tagName === '*';
|
|
765
|
-
|
|
766
|
-
// Recursive function to traverse all descendants
|
|
767
|
-
const traverse = (node: any) => {
|
|
768
|
-
if (node.nodeType === ELEMENT_NODE) {
|
|
769
|
-
const element = node as Element;
|
|
770
|
-
if (isWildcard || element.localName === tagName) {
|
|
771
|
-
result.push(element);
|
|
772
|
-
}
|
|
773
|
-
}
|
|
774
|
-
|
|
775
|
-
// Traverse children
|
|
776
|
-
for (let i = 0; i < node.childNodes.length; i++) {
|
|
777
|
-
traverse(node.childNodes[i]);
|
|
778
|
-
}
|
|
779
|
-
};
|
|
780
|
-
|
|
781
|
-
// Start traversal from this element's children
|
|
782
|
-
for (let i = 0; i < this.childNodes.length; i++) {
|
|
783
|
-
traverse(this.childNodes[i]);
|
|
784
|
-
}
|
|
785
|
-
|
|
786
|
-
return new HTMLCollection(result);
|
|
787
|
-
}
|
|
788
|
-
|
|
789
|
-
getElementsByTagNameNS(namespace: string | null, localName: string): any {
|
|
790
|
-
// For simplicity, we'll implement this similar to getElementsByTagName
|
|
791
|
-
// In a full implementation, namespace handling would be more complex
|
|
792
|
-
return this.getElementsByTagName(localName);
|
|
793
|
-
}
|
|
794
|
-
|
|
795
|
-
getHTML(options?: any): string {
|
|
796
|
-
throw new Error('Element.getHTML() is not implemented yet');
|
|
797
|
-
}
|
|
798
|
-
|
|
799
|
-
hasAttributeNS(namespace: string | null, localName: string): boolean {
|
|
800
|
-
// For simplicity, we'll ignore namespace and use localName
|
|
801
|
-
return this.hasAttribute(localName);
|
|
802
|
-
}
|
|
803
|
-
|
|
804
|
-
hasAttributes(): boolean {
|
|
805
|
-
return this._attributes.size > 0;
|
|
806
|
-
}
|
|
807
|
-
|
|
808
|
-
hasPointerCapture(pointerId: number): boolean {
|
|
809
|
-
throw new Error('Element.hasPointerCapture() is not implemented yet');
|
|
810
|
-
}
|
|
811
|
-
|
|
812
|
-
insertAdjacentElement(where: InsertPosition, element: Element): Element | null {
|
|
813
|
-
const position = where.toLowerCase();
|
|
814
|
-
|
|
815
|
-
switch (position) {
|
|
816
|
-
case 'beforebegin':
|
|
817
|
-
// Insert before this element
|
|
818
|
-
if (this.parentNode) {
|
|
819
|
-
this.parentNode.insertBefore(element as any, this as any);
|
|
820
|
-
return element;
|
|
821
|
-
}
|
|
822
|
-
return null;
|
|
823
|
-
|
|
824
|
-
case 'afterbegin':
|
|
825
|
-
// Insert as first child of this element
|
|
826
|
-
if (this.firstChild) {
|
|
827
|
-
this.insertBefore(element as any, this.firstChild);
|
|
828
|
-
} else {
|
|
829
|
-
this.appendChild(element as any);
|
|
830
|
-
}
|
|
831
|
-
return element;
|
|
832
|
-
|
|
833
|
-
case 'beforeend':
|
|
834
|
-
// Insert as last child of this element
|
|
835
|
-
this.appendChild(element as any);
|
|
836
|
-
return element;
|
|
837
|
-
|
|
838
|
-
case 'afterend':
|
|
839
|
-
// Insert after this element
|
|
840
|
-
if (this.parentNode) {
|
|
841
|
-
if (this.nextSibling) {
|
|
842
|
-
this.parentNode.insertBefore(element as any, this.nextSibling);
|
|
843
|
-
} else {
|
|
844
|
-
this.parentNode.appendChild(element as any);
|
|
845
|
-
}
|
|
846
|
-
return element;
|
|
847
|
-
}
|
|
848
|
-
return null;
|
|
849
|
-
|
|
850
|
-
default:
|
|
851
|
-
throw new DOMException(`Invalid position: ${where}`, 'SyntaxError');
|
|
637
|
+
default:
|
|
638
|
+
throw new DOMException(`Invalid position: ${where}`, 'SyntaxError');
|
|
639
|
+
}
|
|
640
|
+
}
|
|
641
|
+
insertAdjacentHTML(position: InsertPosition, html: string): void {
|
|
642
|
+
const pos = position.toLowerCase();
|
|
643
|
+
const tempDiv = this._ownerDocument.createElement('div');
|
|
644
|
+
tempDiv.innerHTML = html;
|
|
645
|
+
const fragment = this._ownerDocument.createDocumentFragment();
|
|
646
|
+
while (tempDiv.firstChild) fragment.appendChild(tempDiv.firstChild);
|
|
647
|
+
switch (pos) {
|
|
648
|
+
case 'beforebegin':
|
|
649
|
+
if (this.parentNode) this.parentNode.insertBefore(fragment, this as any);
|
|
650
|
+
break;
|
|
651
|
+
case 'afterbegin':
|
|
652
|
+
if (this.firstChild) this.insertBefore(fragment, this.firstChild);
|
|
653
|
+
else this.appendChild(fragment);
|
|
654
|
+
break;
|
|
655
|
+
case 'beforeend':
|
|
656
|
+
this.appendChild(fragment);
|
|
657
|
+
break;
|
|
658
|
+
case 'afterend':
|
|
659
|
+
if (this.parentNode) {
|
|
660
|
+
if (this.nextSibling) this.parentNode.insertBefore(fragment, this.nextSibling);
|
|
661
|
+
else this.parentNode.appendChild(fragment);
|
|
852
662
|
}
|
|
853
|
-
|
|
854
|
-
|
|
855
|
-
|
|
856
|
-
|
|
857
|
-
|
|
858
|
-
|
|
859
|
-
|
|
860
|
-
|
|
861
|
-
|
|
862
|
-
|
|
863
|
-
|
|
864
|
-
|
|
865
|
-
|
|
663
|
+
break;
|
|
664
|
+
default:
|
|
665
|
+
throw new DOMException(`Invalid position: ${position}`, 'SyntaxError');
|
|
666
|
+
}
|
|
667
|
+
}
|
|
668
|
+
insertAdjacentText(where: InsertPosition, data: string): void {
|
|
669
|
+
const position = where.toLowerCase();
|
|
670
|
+
const textNode = this._ownerDocument.createTextNode(data);
|
|
671
|
+
switch (position) {
|
|
672
|
+
case 'beforebegin':
|
|
673
|
+
if (this.parentNode) this.parentNode.insertBefore(textNode, this as any);
|
|
674
|
+
break;
|
|
675
|
+
case 'afterbegin':
|
|
676
|
+
if (this.firstChild) this.insertBefore(textNode, this.firstChild);
|
|
677
|
+
else this.appendChild(textNode);
|
|
678
|
+
break;
|
|
679
|
+
case 'beforeend':
|
|
680
|
+
this.appendChild(textNode);
|
|
681
|
+
break;
|
|
682
|
+
case 'afterend':
|
|
683
|
+
if (this.parentNode) {
|
|
684
|
+
if (this.nextSibling) this.parentNode.insertBefore(textNode, this.nextSibling);
|
|
685
|
+
else this.parentNode.appendChild(textNode);
|
|
866
686
|
}
|
|
867
|
-
|
|
868
|
-
|
|
869
|
-
|
|
870
|
-
|
|
871
|
-
|
|
872
|
-
|
|
873
|
-
|
|
874
|
-
|
|
875
|
-
|
|
876
|
-
|
|
877
|
-
|
|
878
|
-
|
|
879
|
-
|
|
880
|
-
|
|
881
|
-
|
|
882
|
-
|
|
883
|
-
|
|
884
|
-
|
|
885
|
-
|
|
886
|
-
|
|
887
|
-
|
|
888
|
-
|
|
889
|
-
|
|
890
|
-
|
|
891
|
-
|
|
892
|
-
|
|
893
|
-
|
|
894
|
-
|
|
895
|
-
|
|
896
|
-
|
|
897
|
-
|
|
898
|
-
|
|
899
|
-
|
|
900
|
-
|
|
901
|
-
|
|
902
|
-
|
|
903
|
-
|
|
904
|
-
|
|
905
|
-
|
|
906
|
-
|
|
907
|
-
|
|
908
|
-
|
|
909
|
-
|
|
910
|
-
|
|
911
|
-
|
|
912
|
-
|
|
913
|
-
|
|
914
|
-
|
|
915
|
-
|
|
916
|
-
|
|
917
|
-
|
|
918
|
-
|
|
919
|
-
|
|
920
|
-
|
|
921
|
-
|
|
922
|
-
|
|
923
|
-
|
|
924
|
-
|
|
925
|
-
|
|
926
|
-
|
|
927
|
-
|
|
928
|
-
|
|
929
|
-
|
|
930
|
-
|
|
931
|
-
|
|
932
|
-
|
|
933
|
-
|
|
934
|
-
|
|
935
|
-
break;
|
|
936
|
-
|
|
937
|
-
default:
|
|
938
|
-
throw new DOMException(`Invalid position: ${where}`, 'SyntaxError');
|
|
939
|
-
}
|
|
940
|
-
}
|
|
941
|
-
|
|
942
|
-
releasePointerCapture(pointerId: number): void {
|
|
943
|
-
// throw new Error('Element.releasePointerCapture() is not implemented yet');
|
|
944
|
-
}
|
|
945
|
-
|
|
946
|
-
removeAttributeNS(namespace: string | null, localName: string): void {
|
|
947
|
-
// For simplicity, we'll ignore namespace and use localName
|
|
948
|
-
this.removeAttribute(localName);
|
|
949
|
-
}
|
|
950
|
-
|
|
951
|
-
removeAttributeNode(attr: Attr): Attr {
|
|
952
|
-
const oldValue = this.getAttribute(attr.name);
|
|
953
|
-
if (oldValue !== null) {
|
|
954
|
-
this.removeAttribute(attr.name);
|
|
955
|
-
return new AttrImpl(attr.name, oldValue);
|
|
956
|
-
}
|
|
957
|
-
throw new DOMException('The attribute node is not an attribute of this element', 'NotFoundError');
|
|
958
|
-
}
|
|
959
|
-
|
|
960
|
-
requestFullscreen(options?: any): Promise<void> {
|
|
961
|
-
throw new Error('Element.requestFullscreen() is not implemented yet');
|
|
962
|
-
}
|
|
963
|
-
|
|
964
|
-
requestPointerLock(options?: any): Promise<void> {
|
|
965
|
-
throw new Error('Element.requestPointerLock() is not implemented yet');
|
|
966
|
-
}
|
|
967
|
-
|
|
968
|
-
scroll(options?: any): void;
|
|
969
|
-
scroll(x: number, y: number): void;
|
|
970
|
-
scroll(optionsOrX?: any, y?: number): void {
|
|
971
|
-
// throw new Error('Element.scroll() is not implemented yet');
|
|
972
|
-
}
|
|
973
|
-
|
|
974
|
-
scrollBy(options?: any): void;
|
|
975
|
-
scrollBy(x: number, y: number): void;
|
|
976
|
-
scrollBy(optionsOrX?: any, y?: number): void {
|
|
977
|
-
// throw new Error('Element.scrollBy() is not implemented yet');
|
|
978
|
-
}
|
|
979
|
-
|
|
980
|
-
scrollIntoView(arg?: boolean | any): void {
|
|
981
|
-
// throw new Error('Element.scrollIntoView() is not implemented yet');
|
|
982
|
-
}
|
|
983
|
-
|
|
984
|
-
scrollTo(options?: any): void;
|
|
985
|
-
scrollTo(x: number, y: number): void;
|
|
986
|
-
scrollTo(optionsOrX?: any, y?: number): void {
|
|
987
|
-
// throw new Error('Element.scrollTo() is not implemented yet');
|
|
988
|
-
}
|
|
989
|
-
|
|
990
|
-
setAttributeNS(namespace: string | null, qualifiedName: string, value: string): void {
|
|
991
|
-
// For simplicity, we'll ignore namespace and use qualifiedName
|
|
992
|
-
this.setAttribute(qualifiedName, value);
|
|
993
|
-
}
|
|
994
|
-
|
|
995
|
-
setAttributeNode(attr: Attr): Attr | null {
|
|
996
|
-
const oldAttr = this.getAttributeNode(attr.name);
|
|
997
|
-
this.setAttribute(attr.name, attr.value);
|
|
998
|
-
return oldAttr;
|
|
999
|
-
}
|
|
1000
|
-
|
|
1001
|
-
setAttributeNodeNS(attr: Attr): Attr | null {
|
|
1002
|
-
// For simplicity, we'll ignore namespace
|
|
1003
|
-
return this.setAttributeNode(attr);
|
|
1004
|
-
}
|
|
1005
|
-
|
|
1006
|
-
setHTMLUnsafe(html: string): void {
|
|
1007
|
-
// throw new Error('Element.setHTMLUnsafe() is not implemented yet');
|
|
1008
|
-
}
|
|
1009
|
-
|
|
1010
|
-
setPointerCapture(pointerId: number): void {
|
|
1011
|
-
// throw new Error('Element.setPointerCapture() is not implemented yet');
|
|
1012
|
-
}
|
|
1013
|
-
|
|
1014
|
-
toggleAttribute(qualifiedName: string, force?: boolean): boolean {
|
|
1015
|
-
const hasAttr = this.hasAttribute(qualifiedName);
|
|
1016
|
-
|
|
1017
|
-
if (force === true || (force === undefined && !hasAttr)) {
|
|
1018
|
-
this.setAttribute(qualifiedName, '');
|
|
1019
|
-
return true;
|
|
1020
|
-
} else if (force === false || (force === undefined && hasAttr)) {
|
|
1021
|
-
this.removeAttribute(qualifiedName);
|
|
1022
|
-
return false;
|
|
1023
|
-
}
|
|
1024
|
-
|
|
1025
|
-
return hasAttr;
|
|
1026
|
-
}
|
|
1027
|
-
|
|
1028
|
-
webkitMatchesSelector(selectors: string): boolean {
|
|
1029
|
-
// throw new Error('Element.webkitMatchesSelector() is not implemented yet');
|
|
1030
|
-
return false;
|
|
1031
|
-
}
|
|
1032
|
-
|
|
1033
|
-
// EventTarget methods - Not implemented yet
|
|
1034
|
-
addEventListener(type: string, listener: any, options?: any): void {
|
|
1035
|
-
// throw new Error('Element.addEventListener() is not implemented yet');
|
|
1036
|
-
}
|
|
1037
|
-
|
|
1038
|
-
removeEventListener(type: string, listener: any, options?: any): void {
|
|
1039
|
-
// throw new Error('Element.removeEventListener() is not implemented yet');
|
|
1040
|
-
}
|
|
1041
|
-
|
|
1042
|
-
dispatchEvent(event: any): boolean {
|
|
1043
|
-
// throw new Error('Element.dispatchEvent() is not implemented yet');
|
|
1044
|
-
return true;
|
|
1045
|
-
}
|
|
1046
|
-
|
|
1047
|
-
cloneNode(deep?: boolean): ElementBase {
|
|
1048
|
-
// Use ElementFactory to create the correct element type
|
|
1049
|
-
const clone = ElementFactory.createElement(this.tagName, this._ownerDocument);
|
|
1050
|
-
|
|
1051
|
-
// Copy attributes
|
|
1052
|
-
for (const [name, value] of this._attributes) {
|
|
1053
|
-
clone.setAttribute(name, value);
|
|
1054
|
-
}
|
|
1055
|
-
|
|
1056
|
-
// Copy children if deep clone
|
|
1057
|
-
if (deep) {
|
|
1058
|
-
for (const child of this._childNodesInternal) {
|
|
1059
|
-
if (child && 'cloneNode' in child) {
|
|
1060
|
-
clone.appendChild((child as any).cloneNode(true));
|
|
1061
|
-
}
|
|
1062
|
-
}
|
|
1063
|
-
}
|
|
1064
|
-
|
|
1065
|
-
return clone;
|
|
1066
|
-
}
|
|
687
|
+
break;
|
|
688
|
+
default:
|
|
689
|
+
throw new DOMException(`Invalid position: ${where}`, 'SyntaxError');
|
|
690
|
+
}
|
|
691
|
+
}
|
|
692
|
+
releasePointerCapture(_id: number): void {}
|
|
693
|
+
removeAttributeNS(_ns: string | null, localName: string): void {
|
|
694
|
+
this.removeAttribute(localName);
|
|
695
|
+
}
|
|
696
|
+
removeAttributeNode(attr: any): any {
|
|
697
|
+
const oldValue = this.getAttribute(attr.name);
|
|
698
|
+
if (oldValue !== null) {
|
|
699
|
+
this.removeAttribute(attr.name);
|
|
700
|
+
return new AttrImpl(attr.name, oldValue);
|
|
701
|
+
}
|
|
702
|
+
throw new DOMException('The attribute node is not an attribute of this element', 'NotFoundError');
|
|
703
|
+
}
|
|
704
|
+
requestFullscreen(_opt?: any): Promise<void> {
|
|
705
|
+
return Promise.resolve();
|
|
706
|
+
}
|
|
707
|
+
requestPointerLock(_opt?: any): Promise<void> {
|
|
708
|
+
return Promise.resolve();
|
|
709
|
+
}
|
|
710
|
+
scroll(_x?: any, _y?: any): void {}
|
|
711
|
+
scrollBy(_x?: any, _y?: any): void {}
|
|
712
|
+
scrollIntoView(_arg?: any): void {}
|
|
713
|
+
scrollTo(_x?: any, _y?: any): void {}
|
|
714
|
+
setAttributeNS(_ns: string | null, qualifiedName: string, value: string): void {
|
|
715
|
+
this.setAttribute(qualifiedName, value);
|
|
716
|
+
}
|
|
717
|
+
setAttributeNode(attr: any): any {
|
|
718
|
+
const oldAttr = this.getAttributeNode(attr.name);
|
|
719
|
+
this.setAttribute(attr.name, attr.value);
|
|
720
|
+
return oldAttr;
|
|
721
|
+
}
|
|
722
|
+
setAttributeNodeNS(attr: any): any {
|
|
723
|
+
return this.setAttributeNode(attr);
|
|
724
|
+
}
|
|
725
|
+
setHTMLUnsafe(html: string): void {
|
|
726
|
+
this.innerHTML = html;
|
|
727
|
+
}
|
|
728
|
+
setPointerCapture(_id: number): void {}
|
|
729
|
+
toggleAttribute(qualifiedName: string, force?: boolean): boolean {
|
|
730
|
+
const hasAttr = this.hasAttribute(qualifiedName);
|
|
731
|
+
if (force === true || (force === undefined && !hasAttr)) {
|
|
732
|
+
this.setAttribute(qualifiedName, '');
|
|
733
|
+
return true;
|
|
734
|
+
} else if (force === false || (force === undefined && hasAttr)) {
|
|
735
|
+
this.removeAttribute(qualifiedName);
|
|
736
|
+
return false;
|
|
737
|
+
}
|
|
738
|
+
return hasAttr;
|
|
739
|
+
}
|
|
740
|
+
webkitMatchesSelector(selectors: string): boolean {
|
|
741
|
+
return this.matches(selectors);
|
|
742
|
+
}
|
|
743
|
+
addEventListener(type: string, listener: any, options?: any): void {}
|
|
744
|
+
removeEventListener(type: string, listener: any, options?: any): void {}
|
|
745
|
+
dispatchEvent(_event: any): boolean {
|
|
746
|
+
return true;
|
|
747
|
+
}
|
|
748
|
+
cloneNode(deep?: boolean): any {
|
|
749
|
+
const { ElementFactory } = ElementBase.dependencies;
|
|
750
|
+
const clone = ElementFactory.createElement(this.tagName, this._ownerDocument);
|
|
751
|
+
for (const [name, value] of this._attributes) clone.setAttribute(name, value);
|
|
752
|
+
if (deep) for (const child of this._childNodesInternal) if (child && 'cloneNode' in child) clone.appendChild((child as any).cloneNode(true));
|
|
753
|
+
return clone;
|
|
754
|
+
}
|
|
1067
755
|
}
|
|
1068
756
|
|
|
1069
|
-
|
|
757
|
+
//@ts-ignore
|
|
1070
758
|
class DOMTokenListImpl implements DOMTokenList {
|
|
1071
|
-
|
|
1072
|
-
|
|
1073
|
-
|
|
1074
|
-
|
|
1075
|
-
|
|
1076
|
-
|
|
1077
|
-
|
|
1078
|
-
|
|
1079
|
-
|
|
1080
|
-
|
|
1081
|
-
|
|
1082
|
-
|
|
1083
|
-
|
|
1084
|
-
|
|
1085
|
-
|
|
1086
|
-
|
|
1087
|
-
|
|
1088
|
-
|
|
1089
|
-
|
|
1090
|
-
|
|
1091
|
-
|
|
1092
|
-
|
|
1093
|
-
|
|
1094
|
-
|
|
1095
|
-
|
|
1096
|
-
|
|
1097
|
-
|
|
1098
|
-
|
|
1099
|
-
|
|
1100
|
-
|
|
1101
|
-
|
|
1102
|
-
|
|
1103
|
-
}
|
|
1104
|
-
|
|
1105
|
-
|
|
1106
|
-
|
|
1107
|
-
|
|
1108
|
-
|
|
1109
|
-
|
|
1110
|
-
|
|
1111
|
-
|
|
1112
|
-
|
|
1113
|
-
|
|
1114
|
-
|
|
1115
|
-
|
|
1116
|
-
|
|
1117
|
-
|
|
1118
|
-
if (this.contains(oldToken)) {
|
|
1119
|
-
this.remove(oldToken);
|
|
1120
|
-
this.add(newToken);
|
|
1121
|
-
return true;
|
|
1122
|
-
}
|
|
1123
|
-
return false;
|
|
1124
|
-
}
|
|
1125
|
-
|
|
1126
|
-
item(index: number): string | null {
|
|
1127
|
-
const classes = this.element.className.split(/\s+/).filter(c => c.length > 0);
|
|
1128
|
-
return index >= 0 && index < classes.length ? classes[index] : null;
|
|
1129
|
-
}
|
|
1130
|
-
|
|
1131
|
-
[index: number]: string;
|
|
759
|
+
constructor(private element: ElementBase) {}
|
|
760
|
+
|
|
761
|
+
get length(): number {
|
|
762
|
+
return this.element.className.split(/\s+/).filter(c => c.length > 0).length;
|
|
763
|
+
}
|
|
764
|
+
get value(): string {
|
|
765
|
+
return this.element.className;
|
|
766
|
+
}
|
|
767
|
+
set value(value: string) {
|
|
768
|
+
this.element.className = value;
|
|
769
|
+
}
|
|
770
|
+
add(...tokens: string[]): void {
|
|
771
|
+
const classes = new Set(this.element.className.split(/\s+/).filter(c => c.length > 0));
|
|
772
|
+
tokens.forEach(t => classes.add(t));
|
|
773
|
+
this.element.className = Array.from(classes).join(' ');
|
|
774
|
+
}
|
|
775
|
+
remove(...tokens: string[]): void {
|
|
776
|
+
const classes = new Set(this.element.className.split(/\s+/).filter(c => c.length > 0));
|
|
777
|
+
tokens.forEach(t => classes.delete(t));
|
|
778
|
+
this.element.className = Array.from(classes).join(' ');
|
|
779
|
+
}
|
|
780
|
+
contains(token: string): boolean {
|
|
781
|
+
return this.element.className.split(/\s+/).includes(token);
|
|
782
|
+
}
|
|
783
|
+
toggle(token: string, force?: boolean): boolean {
|
|
784
|
+
const hasToken = this.contains(token);
|
|
785
|
+
if (force === true || (force === undefined && !hasToken)) {
|
|
786
|
+
this.add(token);
|
|
787
|
+
return true;
|
|
788
|
+
} else {
|
|
789
|
+
this.remove(token);
|
|
790
|
+
return false;
|
|
791
|
+
}
|
|
792
|
+
}
|
|
793
|
+
replace(oldToken: string, newToken: string): boolean {
|
|
794
|
+
if (this.contains(oldToken)) {
|
|
795
|
+
this.remove(oldToken);
|
|
796
|
+
this.add(newToken);
|
|
797
|
+
return true;
|
|
798
|
+
}
|
|
799
|
+
return false;
|
|
800
|
+
}
|
|
801
|
+
item(index: number): string | null {
|
|
802
|
+
const classes = this.element.className.split(/\s+/).filter(c => c.length > 0);
|
|
803
|
+
return index >= 0 && index < classes.length ? classes[index] : null;
|
|
804
|
+
}
|
|
805
|
+
[index: number]: string;
|
|
1132
806
|
}
|
|
1133
807
|
|
|
1134
|
-
|
|
1135
|
-
|
|
1136
|
-
// Attr implementation
|
|
808
|
+
//@ts-ignore
|
|
1137
809
|
class AttrImpl extends NodeBase implements Attr {
|
|
1138
|
-
|
|
1139
|
-
|
|
1140
|
-
|
|
1141
|
-
|
|
1142
|
-
|
|
1143
|
-
|
|
1144
|
-
|
|
1145
|
-
|
|
1146
|
-
|
|
1147
|
-
|
|
1148
|
-
|
|
1149
|
-
|
|
810
|
+
public ownerElement: Element | null = null;
|
|
811
|
+
public namespaceURI: string | null = null;
|
|
812
|
+
public prefix: string | null = null;
|
|
813
|
+
public specified: boolean = true;
|
|
814
|
+
constructor(
|
|
815
|
+
public name: string,
|
|
816
|
+
public value: string
|
|
817
|
+
) {
|
|
818
|
+
super(ATTRIBUTE_NODE, name);
|
|
819
|
+
}
|
|
820
|
+
get localName(): string {
|
|
821
|
+
return this.name;
|
|
822
|
+
}
|
|
1150
823
|
}
|
|
1151
824
|
|
|
1152
|
-
// NamedNodeMap implementation
|
|
1153
825
|
class NamedNodeMapImpl implements NamedNodeMap {
|
|
1154
|
-
|
|
1155
|
-
|
|
1156
|
-
|
|
1157
|
-
|
|
1158
|
-
|
|
1159
|
-
|
|
1160
|
-
|
|
1161
|
-
|
|
1162
|
-
|
|
1163
|
-
|
|
1164
|
-
|
|
1165
|
-
|
|
1166
|
-
|
|
1167
|
-
|
|
1168
|
-
|
|
1169
|
-
|
|
1170
|
-
|
|
1171
|
-
|
|
1172
|
-
|
|
1173
|
-
|
|
1174
|
-
|
|
1175
|
-
|
|
1176
|
-
|
|
1177
|
-
|
|
1178
|
-
|
|
1179
|
-
|
|
1180
|
-
|
|
1181
|
-
|
|
1182
|
-
|
|
1183
|
-
|
|
1184
|
-
|
|
1185
|
-
|
|
1186
|
-
|
|
1187
|
-
|
|
1188
|
-
|
|
1189
|
-
|
|
1190
|
-
|
|
1191
|
-
|
|
1192
|
-
|
|
1193
|
-
|
|
1194
|
-
|
|
1195
|
-
|
|
1196
|
-
|
|
1197
|
-
|
|
1198
|
-
|
|
1199
|
-
|
|
1200
|
-
|
|
1201
|
-
|
|
1202
|
-
|
|
1203
|
-
|
|
1204
|
-
|
|
1205
|
-
|
|
1206
|
-
|
|
1207
|
-
|
|
1208
|
-
|
|
1209
|
-
|
|
1210
|
-
|
|
1211
|
-
|
|
1212
|
-
|
|
1213
|
-
|
|
1214
|
-
// Additional iterator methods for compatibility
|
|
1215
|
-
keys(): IterableIterator<string> {
|
|
1216
|
-
return this.attributes.keys();
|
|
1217
|
-
}
|
|
1218
|
-
|
|
1219
|
-
values(): IterableIterator<Attr> {
|
|
1220
|
-
const self = this;
|
|
1221
|
-
return (function* () {
|
|
1222
|
-
for (const [key, value] of self.attributes) {
|
|
1223
|
-
yield new AttrImpl(key, value);
|
|
1224
|
-
}
|
|
1225
|
-
})();
|
|
1226
|
-
}
|
|
1227
|
-
|
|
1228
|
-
entries(): IterableIterator<[string, Attr]> {
|
|
1229
|
-
const self = this;
|
|
1230
|
-
return (function* () {
|
|
1231
|
-
for (const [key, value] of self.attributes) {
|
|
1232
|
-
yield [key, new AttrImpl(key, value)] as [string, Attr];
|
|
1233
|
-
}
|
|
1234
|
-
})();
|
|
1235
|
-
}
|
|
1236
|
-
|
|
1237
|
-
// forEach method for compatibility
|
|
1238
|
-
forEach(callback: (attr: Attr, index: number, map: NamedNodeMap) => void, thisArg?: any): void {
|
|
1239
|
-
const keys = Array.from(this.attributes.keys());
|
|
1240
|
-
keys.forEach((key, index) => {
|
|
1241
|
-
const value = this.attributes.get(key)!;
|
|
1242
|
-
const attr = new AttrImpl(key, value);
|
|
1243
|
-
callback.call(thisArg, attr, index, this);
|
|
1244
|
-
});
|
|
1245
|
-
}
|
|
1246
|
-
|
|
1247
|
-
[index: number]: Attr;
|
|
1248
|
-
}
|
|
826
|
+
constructor(private attributes: Map<string, string>) {}
|
|
827
|
+
get length(): number {
|
|
828
|
+
return this.attributes.size;
|
|
829
|
+
}
|
|
830
|
+
getNamedItem(qualifiedName: string): any {
|
|
831
|
+
const value = this.attributes.get(qualifiedName.toLowerCase());
|
|
832
|
+
return value !== undefined ? new AttrImpl(qualifiedName, value) : null;
|
|
833
|
+
}
|
|
834
|
+
getNamedItemNS(_ns: string | null, localName: string): any {
|
|
835
|
+
return this.getNamedItem(localName);
|
|
836
|
+
}
|
|
837
|
+
item(index: number): any {
|
|
838
|
+
const keys = Array.from(this.attributes.keys());
|
|
839
|
+
if (index >= 0 && index < keys.length) return new AttrImpl(keys[index], this.attributes.get(keys[index])!);
|
|
840
|
+
return null;
|
|
841
|
+
}
|
|
842
|
+
removeNamedItem(qualifiedName: string): any {
|
|
843
|
+
const value = this.attributes.get(qualifiedName.toLowerCase());
|
|
844
|
+
if (value !== undefined) {
|
|
845
|
+
this.attributes.delete(qualifiedName.toLowerCase());
|
|
846
|
+
return new AttrImpl(qualifiedName, value);
|
|
847
|
+
}
|
|
848
|
+
throw new DOMException('The attribute is not found', 'NotFoundError');
|
|
849
|
+
}
|
|
850
|
+
removeNamedItemNS(_ns: string | null, localName: string): any {
|
|
851
|
+
return this.removeNamedItem(localName);
|
|
852
|
+
}
|
|
853
|
+
setNamedItem(attr: any): any {
|
|
854
|
+
const oldValue = this.attributes.get(attr.name.toLowerCase());
|
|
855
|
+
this.attributes.set(attr.name.toLowerCase(), attr.value);
|
|
856
|
+
return oldValue !== undefined ? new AttrImpl(attr.name, oldValue) : null;
|
|
857
|
+
}
|
|
858
|
+
setNamedItemNS(attr: any): any {
|
|
859
|
+
return this.setNamedItem(attr);
|
|
860
|
+
}
|
|
861
|
+
*[Symbol.iterator](): any {
|
|
862
|
+
for (const [key, value] of this.attributes) yield new AttrImpl(key, value);
|
|
863
|
+
}
|
|
864
|
+
keys(): any {
|
|
865
|
+
return this.attributes.keys();
|
|
866
|
+
}
|
|
867
|
+
values(): any {
|
|
868
|
+
const self = this;
|
|
869
|
+
return (function* () {
|
|
870
|
+
for (const [key, value] of self.attributes) yield new AttrImpl(key, value);
|
|
871
|
+
})();
|
|
872
|
+
}
|
|
873
|
+
entries(): any {
|
|
874
|
+
const self = this;
|
|
875
|
+
return (function* () {
|
|
876
|
+
for (const [key, value] of self.attributes) yield [key, new AttrImpl(key, value)];
|
|
877
|
+
})();
|
|
878
|
+
}
|
|
879
|
+
forEach(callback: any, thisArg?: any): void {
|
|
880
|
+
const keys = Array.from(this.attributes.keys());
|
|
881
|
+
keys.forEach((key, index) => callback.call(thisArg, new AttrImpl(key, this.attributes.get(key)!), index, this));
|
|
882
|
+
}
|
|
883
|
+
[index: number]: any;
|
|
884
|
+
}
|