HTMLFormElement.h 6.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156
  1. /*
  2. * Copyright (c) 2018-2021, Andreas Kling <andreas@ladybird.org>
  3. * Copyright (c) 2023, Kenneth Myhra <kennethmyhra@serenityos.org>
  4. * Copyright (c) 2023, Luke Wilde <lukew@serenityos.org>
  5. *
  6. * SPDX-License-Identifier: BSD-2-Clause
  7. */
  8. #pragma once
  9. #include <AK/Time.h>
  10. #include <LibWeb/ARIA/Roles.h>
  11. #include <LibWeb/HTML/HTMLElement.h>
  12. #include <LibWeb/HTML/Navigable.h>
  13. namespace Web::HTML {
  14. // https://html.spec.whatwg.org/multipage/form-control-infrastructure.html#attr-fs-method
  15. #define ENUMERATE_FORM_METHOD_ATTRIBUTES \
  16. __ENUMERATE_FORM_METHOD_ATTRIBUTE(get, GET) \
  17. __ENUMERATE_FORM_METHOD_ATTRIBUTE(post, POST) \
  18. __ENUMERATE_FORM_METHOD_ATTRIBUTE(dialog, Dialog)
  19. // https://html.spec.whatwg.org/multipage/form-control-infrastructure.html#attr-fs-enctype
  20. #define ENUMERATE_FORM_METHOD_ENCODING_TYPES \
  21. __ENUMERATE_FORM_METHOD_ENCODING_TYPE("application/x-www-form-urlencoded", FormUrlEncoded) \
  22. __ENUMERATE_FORM_METHOD_ENCODING_TYPE("multipart/form-data", FormData) \
  23. __ENUMERATE_FORM_METHOD_ENCODING_TYPE("text/plain", PlainText)
  24. class HTMLFormElement final : public HTMLElement {
  25. WEB_PLATFORM_OBJECT(HTMLFormElement, HTMLElement);
  26. GC_DECLARE_ALLOCATOR(HTMLFormElement);
  27. public:
  28. virtual ~HTMLFormElement() override;
  29. String action_from_form_element(GC::Ref<HTMLElement> element) const;
  30. enum class MethodAttributeState {
  31. #define __ENUMERATE_FORM_METHOD_ATTRIBUTE(_, state) state,
  32. ENUMERATE_FORM_METHOD_ATTRIBUTES
  33. #undef __ENUMERATE_FORM_METHOD_ATTRIBUTE
  34. };
  35. MethodAttributeState method_state_from_form_element(GC::Ref<HTMLElement const> element) const;
  36. enum class EncodingTypeAttributeState {
  37. #define __ENUMERATE_FORM_METHOD_ENCODING_TYPE(_, state) state,
  38. ENUMERATE_FORM_METHOD_ENCODING_TYPES
  39. #undef __ENUMERATE_FORM_METHOD_ENCODING_TYPE
  40. };
  41. EncodingTypeAttributeState encoding_type_state_from_form_element(GC::Ref<HTMLElement> element) const;
  42. struct SubmitFormOptions {
  43. bool from_submit_binding = { false };
  44. UserNavigationInvolvement user_involvement = { UserNavigationInvolvement::None };
  45. };
  46. WebIDL::ExceptionOr<void> submit_form(GC::Ref<HTMLElement> submitter, SubmitFormOptions);
  47. WebIDL::ExceptionOr<void> implicitly_submit_form();
  48. void reset_form();
  49. // NOTE: This is for the JS bindings. Use submit_form instead.
  50. WebIDL::ExceptionOr<void> submit();
  51. // NOTE: This is for the JS bindings. Use submit_form instead.
  52. WebIDL::ExceptionOr<void> request_submit(GC::Ptr<Element> submitter);
  53. // NOTE: This is for the JS bindings. Use submit_form instead.
  54. void reset();
  55. void add_associated_element(Badge<FormAssociatedElement>, HTMLElement&);
  56. void remove_associated_element(Badge<FormAssociatedElement>, HTMLElement&);
  57. Vector<GC::Ref<DOM::Element>> get_submittable_elements();
  58. GC::Ref<HTMLFormControlsCollection> elements() const;
  59. unsigned length() const;
  60. WebIDL::ExceptionOr<bool> check_validity();
  61. WebIDL::ExceptionOr<bool> report_validity();
  62. // https://www.w3.org/TR/html-aria/#el-form
  63. virtual Optional<ARIA::Role> default_role() const override { return ARIA::Role::form; }
  64. // https://html.spec.whatwg.org/multipage/form-control-infrastructure.html#constructing-entry-list
  65. bool constructing_entry_list() const { return m_constructing_entry_list; }
  66. void set_constructing_entry_list(bool value) { m_constructing_entry_list = value; }
  67. WebIDL::ExceptionOr<void> set_method(String const&);
  68. GC::Ref<DOM::DOMTokenList> rel_list();
  69. String action() const;
  70. WebIDL::ExceptionOr<void> set_action(String const&);
  71. private:
  72. HTMLFormElement(DOM::Document&, DOM::QualifiedName);
  73. virtual bool is_html_form_element() const override { return true; }
  74. virtual void initialize(JS::Realm&) override;
  75. virtual void visit_edges(Cell::Visitor&) override;
  76. // ^PlatformObject
  77. virtual Optional<JS::Value> item_value(size_t index) const override;
  78. virtual JS::Value named_item_value(FlyString const& name) const override;
  79. virtual Vector<FlyString> supported_property_names() const override;
  80. virtual void attribute_changed(FlyString const& name, Optional<String> const& old_value, Optional<String> const& value, Optional<FlyString> const& namespace_) override;
  81. ErrorOr<String> pick_an_encoding() const;
  82. ErrorOr<void> mutate_action_url(URL::URL parsed_action, Vector<XHR::FormDataEntry> entry_list, String encoding, GC::Ref<Navigable> target_navigable, Bindings::NavigationHistoryBehavior history_handling, UserNavigationInvolvement user_involvement);
  83. ErrorOr<void> submit_as_entity_body(URL::URL parsed_action, Vector<XHR::FormDataEntry> entry_list, EncodingTypeAttributeState encoding_type, String encoding, GC::Ref<Navigable> target_navigable, Bindings::NavigationHistoryBehavior history_handling, UserNavigationInvolvement user_involvement);
  84. void get_action_url(URL::URL parsed_action, GC::Ref<Navigable> target_navigable, Bindings::NavigationHistoryBehavior history_handling, UserNavigationInvolvement user_involvement);
  85. ErrorOr<void> mail_with_headers(URL::URL parsed_action, Vector<XHR::FormDataEntry> entry_list, String encoding, GC::Ref<Navigable> target_navigable, Bindings::NavigationHistoryBehavior history_handling, UserNavigationInvolvement user_involvement);
  86. ErrorOr<void> mail_as_body(URL::URL parsed_action, Vector<XHR::FormDataEntry> entry_list, EncodingTypeAttributeState encoding_type, String encoding, GC::Ref<Navigable> target_navigable, Bindings::NavigationHistoryBehavior history_handling, UserNavigationInvolvement user_involvement);
  87. void plan_to_navigate_to(URL::URL url, Variant<Empty, String, POSTResource> post_resource, GC::Ref<Navigable> target_navigable, Bindings::NavigationHistoryBehavior history_handling, UserNavigationInvolvement user_involvement);
  88. FormAssociatedElement* default_button();
  89. size_t number_of_fields_blocking_implicit_submission() const;
  90. bool m_firing_submission_events { false };
  91. // https://html.spec.whatwg.org/multipage/forms.html#locked-for-reset
  92. bool m_locked_for_reset { false };
  93. Vector<GC::Ref<HTMLElement>> m_associated_elements;
  94. // https://html.spec.whatwg.org/multipage/forms.html#past-names-map
  95. struct PastNameEntry {
  96. GC::Ptr<DOM::Node const> node;
  97. MonotonicTime insertion_time;
  98. };
  99. HashMap<FlyString, PastNameEntry> mutable m_past_names_map;
  100. GC::Ptr<HTMLFormControlsCollection> mutable m_elements;
  101. bool m_constructing_entry_list { false };
  102. // https://html.spec.whatwg.org/multipage/form-control-infrastructure.html#planned-navigation
  103. // Each form element has a planned navigation, which is either null or a task; when the form is first created,
  104. // its planned navigation must be set to null.
  105. GC::Ptr<Task const> m_planned_navigation;
  106. GC::Ptr<DOM::DOMTokenList> m_rel_list;
  107. };
  108. }
  109. namespace Web::DOM {
  110. template<>
  111. inline bool Node::fast_is<HTML::HTMLFormElement>() const { return is_html_form_element(); }
  112. }