mirror of
https://github.com/RGBCube/serenity
synced 2025-07-25 06:07:34 +00:00
LibWeb: Make the custom CSSDeclaration methods only work on strings
Otherwise it will try to convert it to a string later anyway. And as far as I'm aware there are no style properties with just a number or JavaScript symbol as name.
This commit is contained in:
parent
e42eaa5d95
commit
a67f0cbfa2
1 changed files with 8 additions and 2 deletions
|
@ -13,13 +13,17 @@ namespace Web::Bindings {
|
||||||
|
|
||||||
bool CSSStyleDeclarationWrapper::internal_has_property(JS::PropertyName const& name) const
|
bool CSSStyleDeclarationWrapper::internal_has_property(JS::PropertyName const& name) const
|
||||||
{
|
{
|
||||||
|
if (!name.is_string())
|
||||||
|
return Base::internal_has_property(name);
|
||||||
// FIXME: These should actually use camelCase versions of the property names!
|
// FIXME: These should actually use camelCase versions of the property names!
|
||||||
auto property_id = CSS::property_id_from_string(name.to_string());
|
auto property_id = CSS::property_id_from_string(name.to_string());
|
||||||
return property_id != CSS::PropertyID::Invalid;
|
return property_id != CSS::PropertyID::Invalid;
|
||||||
}
|
}
|
||||||
|
|
||||||
JS::Value CSSStyleDeclarationWrapper::internal_get(const JS::PropertyName& name, JS::Value receiver) const
|
JS::Value CSSStyleDeclarationWrapper::internal_get(JS::PropertyName const& name, JS::Value receiver) const
|
||||||
{
|
{
|
||||||
|
if (!name.is_string())
|
||||||
|
return Base::internal_get(name, receiver);
|
||||||
// FIXME: These should actually use camelCase versions of the property names!
|
// FIXME: These should actually use camelCase versions of the property names!
|
||||||
auto property_id = CSS::property_id_from_string(name.to_string());
|
auto property_id = CSS::property_id_from_string(name.to_string());
|
||||||
if (property_id == CSS::PropertyID::Invalid)
|
if (property_id == CSS::PropertyID::Invalid)
|
||||||
|
@ -31,8 +35,10 @@ JS::Value CSSStyleDeclarationWrapper::internal_get(const JS::PropertyName& name,
|
||||||
return js_string(vm(), String::empty());
|
return js_string(vm(), String::empty());
|
||||||
}
|
}
|
||||||
|
|
||||||
bool CSSStyleDeclarationWrapper::internal_set(const JS::PropertyName& name, JS::Value value, JS::Value receiver)
|
bool CSSStyleDeclarationWrapper::internal_set(JS::PropertyName const& name, JS::Value value, JS::Value receiver)
|
||||||
{
|
{
|
||||||
|
if (!name.is_string())
|
||||||
|
return Base::internal_set(name, value, receiver);
|
||||||
// FIXME: These should actually use camelCase versions of the property names!
|
// FIXME: These should actually use camelCase versions of the property names!
|
||||||
auto property_id = CSS::property_id_from_string(name.to_string());
|
auto property_id = CSS::property_id_from_string(name.to_string());
|
||||||
if (property_id == CSS::PropertyID::Invalid)
|
if (property_id == CSS::PropertyID::Invalid)
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue