diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 19:33:14 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 19:33:14 +0000 |
commit | 36d22d82aa202bb199967e9512281e9a53db42c9 (patch) | |
tree | 105e8c98ddea1c1e4784a60a5a6410fa416be2de /dom/html/HTMLOptionElement.h | |
parent | Initial commit. (diff) | |
download | firefox-esr-36d22d82aa202bb199967e9512281e9a53db42c9.tar.xz firefox-esr-36d22d82aa202bb199967e9512281e9a53db42c9.zip |
Adding upstream version 115.7.0esr.upstream/115.7.0esr
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'dom/html/HTMLOptionElement.h')
-rw-r--r-- | dom/html/HTMLOptionElement.h | 141 |
1 files changed, 141 insertions, 0 deletions
diff --git a/dom/html/HTMLOptionElement.h b/dom/html/HTMLOptionElement.h new file mode 100644 index 0000000000..3aac4fa0cc --- /dev/null +++ b/dom/html/HTMLOptionElement.h @@ -0,0 +1,141 @@ +/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ +/* vim: set ts=8 sts=2 et sw=2 tw=80: */ +/* This Source Code Form is subject to the terms of the Mozilla Public + * License, v. 2.0. If a copy of the MPL was not distributed with this + * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ + +#ifndef mozilla_dom_HTMLOptionElement_h__ +#define mozilla_dom_HTMLOptionElement_h__ + +#include "mozilla/Attributes.h" +#include "nsGenericHTMLElement.h" +#include "mozilla/dom/HTMLFormElement.h" + +namespace mozilla::dom { + +class HTMLSelectElement; + +class HTMLOptionElement final : public nsGenericHTMLElement { + public: + explicit HTMLOptionElement( + already_AddRefed<mozilla::dom::NodeInfo>&& aNodeInfo); + + static already_AddRefed<HTMLOptionElement> Option( + const GlobalObject& aGlobal, const nsAString& aText, + const Optional<nsAString>& aValue, bool aDefaultSelected, bool aSelected, + ErrorResult& aError); + + NS_IMPL_FROMNODE_HTML_WITH_TAG(HTMLOptionElement, option) + + // nsISupports + NS_INLINE_DECL_REFCOUNTING_INHERITED(HTMLOptionElement, nsGenericHTMLElement) + + using mozilla::dom::Element::GetText; + + bool Selected() const { return mIsSelected; } + void SetSelected(bool aValue); + + void SetSelectedChanged(bool aValue) { mSelectedChanged = aValue; } + + nsChangeHint GetAttributeChangeHint(const nsAtom* aAttribute, + int32_t aModType) const override; + + void BeforeSetAttr(int32_t aNamespaceID, nsAtom* aName, + const nsAttrValue* aValue, bool aNotify) override; + void AfterSetAttr(int32_t aNameSpaceID, nsAtom* aName, + const nsAttrValue* aValue, const nsAttrValue* aOldValue, + nsIPrincipal* aSubjectPrincipal, bool aNotify) override; + + void SetSelectedInternal(bool aValue, bool aNotify); + + /** + * This callback is called by an optgroup on all its option elements whenever + * its disabled state is changed so that option elements can know their + * disabled state might have changed. + */ + void OptGroupDisabledChanged(bool aNotify); + + /** + * Check our disabled content attribute and optgroup's (if it exists) disabled + * state to decide whether our disabled flag should be toggled. + */ + void UpdateDisabledState(bool aNotify); + + nsresult BindToTree(BindContext&, nsINode& aParent) override; + void UnbindFromTree(bool aNullParent = true) override; + + // nsIContent + ElementState IntrinsicState() const override; + + nsresult Clone(dom::NodeInfo*, nsINode** aResult) const override; + + nsresult CopyInnerTo(mozilla::dom::Element* aDest); + + bool Disabled() const { return GetBoolAttr(nsGkAtoms::disabled); } + + void SetDisabled(bool aValue, ErrorResult& aRv) { + SetHTMLBoolAttr(nsGkAtoms::disabled, aValue, aRv); + } + + HTMLFormElement* GetForm(); + + void GetRenderedLabel(nsAString& aLabel) { + if (!GetAttr(kNameSpaceID_None, nsGkAtoms::label, aLabel) || + aLabel.IsEmpty()) { + GetText(aLabel); + } + } + + void GetLabel(nsAString& aLabel) { + if (!GetAttr(kNameSpaceID_None, nsGkAtoms::label, aLabel)) { + GetText(aLabel); + } + } + void SetLabel(const nsAString& aLabel, ErrorResult& aError) { + SetHTMLAttr(nsGkAtoms::label, aLabel, aError); + } + + bool DefaultSelected() const { + return HasAttr(kNameSpaceID_None, nsGkAtoms::selected); + } + void SetDefaultSelected(bool aValue, ErrorResult& aRv) { + SetHTMLBoolAttr(nsGkAtoms::selected, aValue, aRv); + } + + void GetValue(nsAString& aValue) { + if (!GetAttr(kNameSpaceID_None, nsGkAtoms::value, aValue)) { + GetText(aValue); + } + } + void SetValue(const nsAString& aValue, ErrorResult& aRv) { + SetHTMLAttr(nsGkAtoms::value, aValue, aRv); + } + + void GetText(nsAString& aText); + void SetText(const nsAString& aText, ErrorResult& aRv); + + int32_t Index(); + + protected: + virtual ~HTMLOptionElement(); + + JSObject* WrapNode(JSContext*, JS::Handle<JSObject*> aGivenProto) override; + + /** + * Get the select content element that contains this option, this + * intentionally does not return nsresult, all we care about is if + * there's a select associated with this option or not. + */ + HTMLSelectElement* GetSelect(); + + bool mSelectedChanged; + bool mIsSelected; + + // True only while we're under the SetOptionsSelectedByIndex call when our + // "selected" attribute is changing and mSelectedChanged is false. + bool mIsInSetDefaultSelected; +}; + +} // namespace mozilla::dom + +#endif // mozilla_dom_HTMLOptionElement_h__ |