HTMLTextAreaElement.h [plain text]
#pragma once
#include "HTMLTextFormControlElement.h"
namespace WebCore {
class BeforeTextInsertedEvent;
class RenderTextControlMultiLine;
class VisibleSelection;
class HTMLTextAreaElement final : public HTMLTextFormControlElement {
public:
static Ref<HTMLTextAreaElement> create(const QualifiedName&, Document&, HTMLFormElement*);
unsigned cols() const { return m_cols; }
unsigned rows() const { return m_rows; }
bool shouldWrapText() const { return m_wrap != NoWrap; }
WEBCORE_EXPORT String value() const final;
WEBCORE_EXPORT void setValue(const String&);
WEBCORE_EXPORT String defaultValue() const;
WEBCORE_EXPORT void setDefaultValue(const String&);
int textLength() const { return value().length(); }
int effectiveMaxLength() const { return maxLength(); }
String validationMessage() const final;
bool valueMissing() const final;
bool tooShort() const final;
bool tooLong() const final;
bool isValidValue(const String&) const;
TextControlInnerTextElement* innerTextElement() const final;
RenderStyle createInnerTextStyle(const RenderStyle&) const final;
void copyNonAttributePropertiesFromElement(const Element&) final;
void rendererWillBeDestroyed();
WEBCORE_EXPORT void setCols(unsigned);
WEBCORE_EXPORT void setRows(unsigned);
bool willRespondToMouseClickEvents() final;
RenderTextControlMultiLine* renderer() const;
private:
HTMLTextAreaElement(const QualifiedName&, Document&, HTMLFormElement*);
enum WrapMethod { NoWrap, SoftWrap, HardWrap };
void didAddUserAgentShadowRoot(ShadowRoot*) final;
void maxLengthAttributeChanged(const AtomicString& newValue);
void minLengthAttributeChanged(const AtomicString& newValue);
void handleBeforeTextInsertedEvent(BeforeTextInsertedEvent&) const;
static String sanitizeUserInputValue(const String&, unsigned maxLength);
void updateValue() const;
void setNonDirtyValue(const String&);
void setValueCommon(const String&);
bool supportsPlaceholder() const final { return true; }
HTMLElement* placeholderElement() const final;
void updatePlaceholderText() final;
bool isEmptyValue() const final { return value().isEmpty(); }
bool isOptionalFormControl() const final { return !isRequiredFormControl(); }
bool isRequiredFormControl() const final { return isRequired(); }
void defaultEventHandler(Event&) final;
void subtreeHasChanged() final;
bool isEnumeratable() const final { return true; }
bool supportLabels() const final { return true; }
const AtomicString& formControlType() const final;
FormControlState saveFormControlState() const final;
void restoreFormControlState(const FormControlState&) final;
bool isTextFormControl() const final { return true; }
void childrenChanged(const ChildChange&) final;
void parseAttribute(const QualifiedName&, const AtomicString&) final;
bool isPresentationAttribute(const QualifiedName&) const final;
void collectStyleForPresentationAttribute(const QualifiedName&, const AtomicString&, MutableStyleProperties&) final;
RenderPtr<RenderElement> createElementRenderer(RenderStyle&&, const RenderTreePosition&) final;
bool appendFormData(FormDataList&, bool) final;
void reset() final;
bool hasCustomFocusLogic() const final;
bool isMouseFocusable() const final;
bool isKeyboardFocusable(KeyboardEvent&) const final;
void updateFocusAppearance(SelectionRestorationMode, SelectionRevealMode) final;
void accessKeyAction(bool sendMouseEvents) final;
bool shouldUseInputMethod() final;
bool matchesReadWritePseudoClass() const final;
bool valueMissing(const String& value) const { return isRequiredFormControl() && !isDisabledOrReadOnly() && value.isEmpty(); }
bool tooShort(StringView, NeedsToCheckDirtyFlag) const;
bool tooLong(StringView, NeedsToCheckDirtyFlag) const;
unsigned m_rows;
unsigned m_cols;
WrapMethod m_wrap { SoftWrap };
RefPtr<HTMLElement> m_placeholder;
mutable String m_value;
mutable bool m_isDirty { false };
mutable bool m_wasModifiedByUser { false };
};
}