mirror of
https://github.com/RGBCube/serenity
synced 2025-07-26 05:47:34 +00:00
LibWeb: Add CSS.escape() JS function
This is the `CSS` namespace defined in IDL here: https://www.w3.org/TR/cssom-1/#namespacedef-css , not to be confused with our `Web::CSS` namespace. Words are hard. `CSS.escape()` lets you escape identifiers that can then be used to create a CSS string. I've also stubbed out the `CSS.supports()` function.
This commit is contained in:
parent
3c0b55c284
commit
575ce04148
6 changed files with 209 additions and 0 deletions
75
Userland/Libraries/LibWeb/Bindings/CSSNamespace.cpp
Normal file
75
Userland/Libraries/LibWeb/Bindings/CSSNamespace.cpp
Normal file
|
@ -0,0 +1,75 @@
|
|||
/*
|
||||
* Copyright (c) 2021, Sam Atkins <atkinssj@serenityos.org>
|
||||
*
|
||||
* SPDX-License-Identifier: BSD-2-Clause
|
||||
*/
|
||||
|
||||
#include <LibJS/Runtime/ErrorTypes.h>
|
||||
#include <LibJS/Runtime/GlobalObject.h>
|
||||
#include <LibJS/Runtime/VM.h>
|
||||
#include <LibJS/Runtime/Value.h>
|
||||
#include <LibWeb/Bindings/CSSNamespace.h>
|
||||
|
||||
namespace Web::Bindings {
|
||||
|
||||
CSSNamespace::CSSNamespace(JS::GlobalObject& global_object)
|
||||
: JS::Object(*global_object.object_prototype())
|
||||
{
|
||||
}
|
||||
|
||||
CSSNamespace::~CSSNamespace()
|
||||
{
|
||||
}
|
||||
|
||||
void CSSNamespace::initialize(JS::GlobalObject& global_object)
|
||||
{
|
||||
Object::initialize(global_object);
|
||||
u8 attr = JS::Attribute::Enumerable;
|
||||
define_native_function("escape", escape, 1, attr);
|
||||
define_native_function("supports", supports, 2, attr);
|
||||
}
|
||||
|
||||
// https://www.w3.org/TR/cssom-1/#dom-css-escape
|
||||
JS_DEFINE_NATIVE_FUNCTION(CSSNamespace::escape)
|
||||
{
|
||||
if (!vm.argument_count()) {
|
||||
vm.throw_exception<JS::TypeError>(global_object, JS::ErrorType::BadArgCountAtLeastOne, "CSS.escape");
|
||||
return {};
|
||||
}
|
||||
|
||||
String result = Web::CSS::serialize_an_identifier(vm.argument(0).to_string(global_object));
|
||||
if (vm.exception())
|
||||
return {};
|
||||
|
||||
return JS::Value(JS::js_string(vm, result));
|
||||
}
|
||||
|
||||
// https://www.w3.org/TR/css-conditional-3/#dom-css-supports
|
||||
JS_DEFINE_NATIVE_FUNCTION(CSSNamespace::supports)
|
||||
{
|
||||
if (!vm.argument_count()) {
|
||||
vm.throw_exception<JS::TypeError>(global_object, JS::ErrorType::BadArgCountAtLeastOne, "CSS.supports");
|
||||
return {};
|
||||
}
|
||||
|
||||
if (vm.argument_count() >= 2) {
|
||||
// When the supports(property, value) method is invoked with two arguments property and value:
|
||||
// If property is an ASCII case-insensitive match for any defined CSS property that the UA supports, and value successfully parses according to that property’s grammar, return true.
|
||||
//
|
||||
// Otherwise, if property is a custom property name string, return true.
|
||||
//
|
||||
// Otherwise, return false.
|
||||
return JS::Value(false);
|
||||
} else {
|
||||
// When the supports(conditionText) method is invoked with a single conditionText argument:
|
||||
//
|
||||
// If conditionText, parsed and evaluated as a <supports-condition>, would return true, return true.
|
||||
//
|
||||
// Otherwise, If conditionText, wrapped in parentheses and then parsed and evaluated as a <supports-condition>, would return true, return true.
|
||||
//
|
||||
// Otherwise, return false.
|
||||
return JS::Value(false);
|
||||
}
|
||||
}
|
||||
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue