mirror of
https://github.com/LadybirdBrowser/ladybird.git
synced 2025-04-20 11:36:10 +00:00
LibWeb: Implement the "backColor" and "hiliteColor" editing commands
This commit is contained in:
parent
7736d63290
commit
05386fe99c
Notes:
github-actions[bot]
2025-01-10 22:37:15 +00:00
Author: https://github.com/gmta Commit: https://github.com/LadybirdBrowser/ladybird/commit/05386fe99c1 Pull-request: https://github.com/LadybirdBrowser/ladybird/pull/3216
4 changed files with 59 additions and 0 deletions
|
@ -25,6 +25,28 @@
|
|||
|
||||
namespace Web::Editing {
|
||||
|
||||
// https://w3c.github.io/editing/docs/execCommand/#the-backcolor-command
|
||||
bool command_back_color_action(DOM::Document& document, String const& value)
|
||||
{
|
||||
// 1. If value is not a valid CSS color, prepend "#" to it.
|
||||
auto resulting_value = value;
|
||||
if (!Color::from_string(resulting_value).has_value()) {
|
||||
resulting_value = MUST(String::formatted("#{}", resulting_value));
|
||||
|
||||
// 2. If value is still not a valid CSS color, or if it is currentColor, return false.
|
||||
if (!Color::from_string(resulting_value).has_value()) {
|
||||
// FIXME: Also return false in case of currentColor.
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
// 3. Set the selection's value to value.
|
||||
set_the_selections_value(document, CommandNames::backColor, resulting_value);
|
||||
|
||||
// 4. Return true.
|
||||
return true;
|
||||
}
|
||||
|
||||
// https://w3c.github.io/editing/docs/execCommand/#the-bold-command
|
||||
bool command_bold_action(DOM::Document& document, String const&)
|
||||
{
|
||||
|
@ -1030,6 +1052,12 @@ bool command_style_with_css_state(DOM::Document const& document)
|
|||
}
|
||||
|
||||
static Array const commands {
|
||||
// https://w3c.github.io/editing/docs/execCommand/#the-backcolor-command
|
||||
CommandDefinition {
|
||||
.command = CommandNames::backColor,
|
||||
.action = command_back_color_action,
|
||||
.relevant_css_property = CSS::PropertyID::BackgroundColor,
|
||||
},
|
||||
// https://w3c.github.io/editing/docs/execCommand/#the-bold-command
|
||||
CommandDefinition {
|
||||
.command = CommandNames::bold,
|
||||
|
@ -1055,6 +1083,12 @@ static Array const commands {
|
|||
.action = command_forward_delete_action,
|
||||
.preserves_overrides = true,
|
||||
},
|
||||
// https://w3c.github.io/editing/docs/execCommand/#the-hilitecolor-command
|
||||
CommandDefinition {
|
||||
.command = CommandNames::hiliteColor,
|
||||
.action = command_back_color_action, // For historical reasons, backColor and hiliteColor behave identically.
|
||||
.relevant_css_property = CSS::PropertyID::BackgroundColor,
|
||||
},
|
||||
// https://w3c.github.io/editing/docs/execCommand/#the-insertlinebreak-command
|
||||
CommandDefinition {
|
||||
.command = CommandNames::insertLineBreak,
|
||||
|
|
|
@ -29,6 +29,7 @@ struct CommandDefinition {
|
|||
Optional<CommandDefinition const&> find_command_definition(FlyString const&);
|
||||
|
||||
// Command implementations
|
||||
bool command_back_color_action(DOM::Document&, String const&);
|
||||
bool command_bold_action(DOM::Document&, String const&);
|
||||
bool command_default_paragraph_separator_action(DOM::Document&, String const&);
|
||||
String command_default_paragraph_separator_value(DOM::Document const&);
|
||||
|
|
|
@ -0,0 +1,2 @@
|
|||
Div contents: "<span style="background-color: rgb(0, 0, 255);">foo</span>bar"
|
||||
Div contents: "<span style="background-color: rgb(0, 0, 255);">foo</span><span style="background-color: red;">bar</span>"
|
22
Tests/LibWeb/Text/input/Editing/execCommand-backColor.html
Normal file
22
Tests/LibWeb/Text/input/Editing/execCommand-backColor.html
Normal file
|
@ -0,0 +1,22 @@
|
|||
<script src="../include.js"></script>
|
||||
<div contenteditable="true">foobar</div>
|
||||
<script>
|
||||
test(() => {
|
||||
const range = document.createRange();
|
||||
getSelection().addRange(range);
|
||||
|
||||
const divElm = document.querySelector('div');
|
||||
|
||||
// Make 'foo' blue
|
||||
range.setStart(divElm.childNodes[0], 0);
|
||||
range.setEnd(divElm.childNodes[0], 3);
|
||||
document.execCommand('backColor', false, '#0000ff');
|
||||
println(`Div contents: "${divElm.innerHTML}"`);
|
||||
|
||||
// Make 'bar' red
|
||||
range.setStart(divElm.childNodes[1], 0);
|
||||
range.setEnd(divElm.childNodes[1], 3);
|
||||
document.execCommand('hiliteColor', false, 'red');
|
||||
println(`Div contents: "${divElm.innerHTML}"`);
|
||||
});
|
||||
</script>
|
Loading…
Add table
Reference in a new issue