mirror of
https://github.com/LadybirdBrowser/ladybird.git
synced 2025-08-23 10:50:49 +00:00
LibWeb: Implement CSSImportRule.supportsText
Returns the supports condition specified by the given import at-rule.
This commit is contained in:
parent
c37a47f76f
commit
5d57723ebf
Notes:
github-actions[bot]
2025-03-19 15:43:53 +00:00
Author: https://github.com/tcl3
Commit: 5d57723ebf
Pull-request: https://github.com/LadybirdBrowser/ladybird/pull/4001
Reviewed-by: https://github.com/AtkinsSJ
Reviewed-by: https://github.com/gmta ✅
7 changed files with 35 additions and 3 deletions
|
@ -171,4 +171,11 @@ void CSSImportRule::set_style_sheet(GC::Ref<CSSStyleSheet> style_sheet)
|
|||
m_document->invalidate_style(DOM::StyleInvalidationReason::CSSImportRule);
|
||||
}
|
||||
|
||||
Optional<String> CSSImportRule::supports_text() const
|
||||
{
|
||||
if (!m_supports)
|
||||
return {};
|
||||
return m_supports->to_string();
|
||||
}
|
||||
|
||||
}
|
||||
|
|
|
@ -33,6 +33,8 @@ public:
|
|||
CSSStyleSheet const* loaded_style_sheet() const { return m_style_sheet; }
|
||||
CSSStyleSheet* style_sheet_for_bindings() { return m_style_sheet; }
|
||||
|
||||
Optional<String> supports_text() const;
|
||||
|
||||
private:
|
||||
CSSImportRule(URL::URL, DOM::Document&, RefPtr<Supports>);
|
||||
|
||||
|
|
|
@ -9,5 +9,5 @@ interface CSSImportRule : CSSRule {
|
|||
// FIXME: [SameObject, PutForwards=mediaText] readonly attribute MediaList media;
|
||||
[SameObject, ImplementedAs=style_sheet_for_bindings] readonly attribute CSSStyleSheet? styleSheet;
|
||||
[FIXME] readonly attribute CSSOMString? layerName;
|
||||
[FIXME] readonly attribute CSSOMString? supportsText;
|
||||
readonly attribute CSSOMString? supportsText;
|
||||
};
|
||||
|
|
|
@ -291,9 +291,11 @@ OwnPtr<BooleanExpression> Parser::parse_supports_feature(TokenStream<ComponentVa
|
|||
// FIXME: Parsing and then converting back to a string is weird.
|
||||
if (auto declaration = consume_a_declaration(block_tokens); declaration.has_value()) {
|
||||
transaction.commit();
|
||||
return Supports::Declaration::create(
|
||||
auto supports_declaration = Supports::Declaration::create(
|
||||
declaration->to_string(),
|
||||
convert_to_style_property(*declaration).has_value());
|
||||
|
||||
return BooleanExpressionInParens::create(supports_declaration.release_nonnull<BooleanExpression>());
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
@ -22,7 +22,7 @@ MatchResult Supports::Declaration::evaluate(HTML::Window const*) const
|
|||
|
||||
String Supports::Declaration::to_string() const
|
||||
{
|
||||
return MUST(String::formatted("({})", m_declaration));
|
||||
return m_declaration;
|
||||
}
|
||||
|
||||
void Supports::Declaration::dump(StringBuilder& builder, int indent_levels) const
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue