diff options
author | Matt A. Tobin <email@mattatobin.com> | 2020-04-17 07:05:27 -0400 |
---|---|---|
committer | Matt A. Tobin <email@mattatobin.com> | 2020-04-17 07:05:27 -0400 |
commit | 3a74795a56e92313c1b33a54500917794ba09b72 (patch) | |
tree | 949f2d97d27713e6a8960b948e51644bcaf27c02 /dom | |
parent | 873abc7bcb6adc5cbf98ba3e1bd9a3271afc9806 (diff) | |
download | uxp-3a74795a56e92313c1b33a54500917794ba09b72.tar.gz |
Bug 1411878 - Support Element.shadowRoot and Element.assignedSlot / TextNode.assignedSlot on closed shadow root
Tag #1375
Diffstat (limited to 'dom')
-rw-r--r-- | dom/base/Element.cpp | 19 | ||||
-rw-r--r-- | dom/base/Element.h | 1 | ||||
-rw-r--r-- | dom/base/FragmentOrElement.cpp | 30 | ||||
-rw-r--r-- | dom/base/ShadowRoot.h | 5 | ||||
-rw-r--r-- | dom/base/nsIContent.h | 9 | ||||
-rw-r--r-- | dom/webidl/Element.webidl | 4 | ||||
-rw-r--r-- | dom/webidl/Text.webidl | 2 |
7 files changed, 67 insertions, 3 deletions
diff --git a/dom/base/Element.cpp b/dom/base/Element.cpp index 638d6674d2..cd803a60f9 100644 --- a/dom/base/Element.cpp +++ b/dom/base/Element.cpp @@ -1104,6 +1104,25 @@ Element::GetSlot(nsAString& aName) GetAttr(kNameSpaceID_None, nsGkAtoms::slot, aName); } +// https://dom.spec.whatwg.org/#dom-element-shadowroot +ShadowRoot* +Element::GetShadowRootByMode() const +{ + /** + * 1. Let shadow be context object’s shadow root. + * 2. If shadow is null or its mode is "closed", then return null. + */ + ShadowRoot* shadowRoot = GetShadowRoot(); + if (!shadowRoot || shadowRoot->IsClosed()) { + return nullptr; + } + + /** + * 3. Return shadow. + */ + return shadowRoot; +} + // https://dom.spec.whatwg.org/#dom-element-attachshadow already_AddRefed<ShadowRoot> Element::AttachShadow(const ShadowRootInit& aInit, ErrorResult& aError) diff --git a/dom/base/Element.h b/dom/base/Element.h index 6169fbdab9..23a9fee522 100644 --- a/dom/base/Element.h +++ b/dom/base/Element.h @@ -927,6 +927,7 @@ public: // Shadow DOM v1 already_AddRefed<ShadowRoot> AttachShadow(const ShadowRootInit& aInit, ErrorResult& aError); + ShadowRoot* GetShadowRootByMode() const; void SetSlot(const nsAString& aName, ErrorResult& aError); void GetSlot(nsAString& aName); diff --git a/dom/base/FragmentOrElement.cpp b/dom/base/FragmentOrElement.cpp index 486bbc88c4..766e2b1158 100644 --- a/dom/base/FragmentOrElement.cpp +++ b/dom/base/FragmentOrElement.cpp @@ -152,6 +152,36 @@ nsIContent::FindFirstNonChromeOnlyAccessContent() const return nullptr; } +// https://dom.spec.whatwg.org/#dom-slotable-assignedslot +HTMLSlotElement* +nsIContent::GetAssignedSlotByMode() const +{ + /** + * Get slotable's assigned slot for the result of + * find a slot with open flag UNSET [1]. + * + * [1] https://dom.spec.whatwg.org/#assign-a-slot + */ + HTMLSlotElement* slot = GetAssignedSlot(); + if (!slot) { + return nullptr; + } + + MOZ_ASSERT(GetParent()); + MOZ_ASSERT(GetParent()->GetShadowRoot()); + + /** + * Additional check for open flag SET: + * If slotable’s parent’s shadow root's mode is not "open", + * then return null. + */ + if (GetParent()->GetShadowRoot()->IsClosed()) { + return nullptr; + } + + return slot; +} + nsINode* nsIContent::GetFlattenedTreeParentNodeInternal(FlattenedParentType aType) const { diff --git a/dom/base/ShadowRoot.h b/dom/base/ShadowRoot.h index f061735e2a..4a5b54e85a 100644 --- a/dom/base/ShadowRoot.h +++ b/dom/base/ShadowRoot.h @@ -51,6 +51,11 @@ public: { return mMode; } + bool IsClosed() + { + return mMode == ShadowRootMode::Closed; + } + // [deprecated] Shadow DOM v0 void AddToIdTable(Element* aElement, nsIAtom* aId); diff --git a/dom/base/nsIContent.h b/dom/base/nsIContent.h index f368497f44..8da0ba7f2b 100644 --- a/dom/base/nsIContent.h +++ b/dom/base/nsIContent.h @@ -725,6 +725,15 @@ public: virtual void SetAssignedSlot(mozilla::dom::HTMLSlotElement* aSlot) = 0; /** + * Gets the assigned slot associated with this content based on parent's + * shadow root mode. Returns null if parent's shadow root is "closed". + * https://dom.spec.whatwg.org/#dom-slotable-assignedslot + * + * @return The assigned slot element or null. + */ + mozilla::dom::HTMLSlotElement* GetAssignedSlotByMode() const; + + /** * Gets the insertion parent element of the XBL binding. * The insertion parent is our one true parent in the transformed DOM. * diff --git a/dom/webidl/Element.webidl b/dom/webidl/Element.webidl index ddc5484421..f6d0f7f93e 100644 --- a/dom/webidl/Element.webidl +++ b/dom/webidl/Element.webidl @@ -238,9 +238,9 @@ partial interface Element { // Shadow DOM v1 [Throws, Pref="nsDocument::IsWebComponentsEnabled"] ShadowRoot attachShadow(ShadowRootInit shadowRootInitDict); - [Func="nsDocument::IsWebComponentsEnabled"] + [BinaryName="shadowRootByMode", Func="nsDocument::IsWebComponentsEnabled"] readonly attribute ShadowRoot? shadowRoot; - [Pref="nsDocument::IsWebComponentsEnabled"] + [BinaryName="assignedSlotByMode", Pref="nsDocument::IsWebComponentsEnabled"] readonly attribute HTMLSlotElement? assignedSlot; [CEReactions, Unscopable, SetterThrows, Pref="nsDocument::IsWebComponentsEnabled"] attribute DOMString slot; diff --git a/dom/webidl/Text.webidl b/dom/webidl/Text.webidl index f7bd1a9711..c40b71cc53 100644 --- a/dom/webidl/Text.webidl +++ b/dom/webidl/Text.webidl @@ -19,7 +19,7 @@ interface Text : CharacterData { }; partial interface Text { - [Pref="dom.webcomponents.enabled"] + [BinaryName="assignedSlotByMode", Pref="dom.webcomponents.enabled"] readonly attribute HTMLSlotElement? assignedSlot; }; |