2020-08-01 03:05:43 +01:00
|
|
|
/*
|
2021-04-28 22:46:44 +02:00
|
|
|
* Copyright (c) 2020, the SerenityOS developers.
|
2020-08-01 03:05:43 +01:00
|
|
|
*
|
2021-04-22 01:24:48 -07:00
|
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
2020-08-01 03:05:43 +01:00
|
|
|
*/
|
|
|
|
|
2024-04-27 12:09:58 +12:00
|
|
|
#include <LibWeb/Bindings/HTMLOptGroupElementPrototype.h>
|
2022-09-30 17:16:16 -06:00
|
|
|
#include <LibWeb/Bindings/Intrinsics.h>
|
2020-08-01 03:05:43 +01:00
|
|
|
#include <LibWeb/HTML/HTMLOptGroupElement.h>
|
2024-11-14 00:05:38 +01:00
|
|
|
#include <LibWeb/HTML/HTMLSelectElement.h>
|
2020-08-01 03:05:43 +01:00
|
|
|
|
|
|
|
namespace Web::HTML {
|
|
|
|
|
2024-11-15 04:01:23 +13:00
|
|
|
GC_DEFINE_ALLOCATOR(HTMLOptGroupElement);
|
2023-11-19 19:47:52 +01:00
|
|
|
|
2022-02-18 21:00:52 +01:00
|
|
|
HTMLOptGroupElement::HTMLOptGroupElement(DOM::Document& document, DOM::QualifiedName qualified_name)
|
2021-02-07 11:20:15 +01:00
|
|
|
: HTMLElement(document, move(qualified_name))
|
2020-08-01 03:05:43 +01:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2022-03-14 13:21:51 -06:00
|
|
|
HTMLOptGroupElement::~HTMLOptGroupElement() = default;
|
2020-08-01 03:05:43 +01:00
|
|
|
|
2023-08-07 08:41:28 +02:00
|
|
|
void HTMLOptGroupElement::initialize(JS::Realm& realm)
|
2023-01-10 06:28:20 -05:00
|
|
|
{
|
2023-08-07 08:41:28 +02:00
|
|
|
Base::initialize(realm);
|
2024-03-16 13:13:08 +01:00
|
|
|
WEB_SET_PROTOTYPE_FOR_INTERFACE(HTMLOptGroupElement);
|
2023-01-10 06:28:20 -05:00
|
|
|
}
|
|
|
|
|
2024-11-14 00:05:38 +01:00
|
|
|
void HTMLOptGroupElement::inserted()
|
|
|
|
{
|
|
|
|
Base::inserted();
|
|
|
|
|
|
|
|
// AD-HOC: We update the selectedness of our <select> parent here,
|
|
|
|
// to ensure that the correct <option> is selected after an <optgroup> is dynamically inserted.
|
|
|
|
if (is<HTMLSelectElement>(*parent()) && first_child_of_type<HTMLOptionElement>())
|
|
|
|
static_cast<HTMLSelectElement&>(*parent()).update_selectedness();
|
|
|
|
}
|
|
|
|
|
|
|
|
void HTMLOptGroupElement::removed_from(Node* old_parent)
|
|
|
|
{
|
|
|
|
Base::removed_from(old_parent);
|
|
|
|
|
|
|
|
// The optgroup HTML element removing steps, given removedNode and oldParent, are:
|
|
|
|
// 1. If oldParent is a select element and removedNode has an option child, then run oldParent's selectedness setting algorithm.
|
|
|
|
if (old_parent && is<HTMLSelectElement>(*old_parent) && first_child_of_type<HTMLOptionElement>())
|
|
|
|
static_cast<HTMLSelectElement&>(*old_parent).update_selectedness();
|
|
|
|
}
|
|
|
|
|
2020-08-01 03:05:43 +01:00
|
|
|
}
|