Source code
Revision control
Copy as Markdown
Other Tools
Test Info:
- This WPT test may be referenced by the following Test IDs:
- /editing/plaintext-only/forwardDelete-around-linebreak-or-block-boundary.html?white-space=normal - WPT Dashboard Interop Dashboard
- /editing/plaintext-only/forwardDelete-around-linebreak-or-block-boundary.html?white-space=pre - WPT Dashboard Interop Dashboard
- /editing/plaintext-only/forwardDelete-around-linebreak-or-block-boundary.html?white-space=pre-line - WPT Dashboard Interop Dashboard
- /editing/plaintext-only/forwardDelete-around-linebreak-or-block-boundary.html?white-space=pre-wrap - WPT Dashboard Interop Dashboard
<!doctype html>
<html>
<head>
<meta charset="utf-8">
<meta name="timeout" content="long">
<meta name="variant" content="?white-space=normal">
<meta name="variant" content="?white-space=pre">
<meta name="variant" content="?white-space=pre-line">
<meta name="variant" content="?white-space=pre-wrap">
<title>Making block empty or joining paragraphs in contenteditable=plaintext-only should work as same as contenteditable=true</title>
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>
<script src="../include/editor-test-utils.js"></script>
<script>
"use strict";
const searchParams = new URLSearchParams(document.location.search);
const whiteSpace = searchParams.get("white-space");
const useBR = whiteSpace == "normal";
/**
* contenteditable=plaintext-only may have any complicated DOM tree. Therefore,
* deletion around line breaks and block boundaries should work same as the
* case of contenteditable=true.
*/
addEventListener("load", () => {
const richTextEditingHost = document.querySelector("div[contenteditable=true]");
richTextEditingHost.style.whiteSpace = whiteSpace;
const plainTextEditingHost = document.querySelector("div[contenteditable=plaintext-only]");
plainTextEditingHost.style.whiteSpace = whiteSpace;
const utilsForRichText = new EditorTestUtils(richTextEditingHost);
const utilsForPlainText = new EditorTestUtils(plainTextEditingHost);
for (const data of [
{
init: `<div>[]A</div>`,
},
{
init: `<div>A[]<br>B</div>`,
},
{
init: `<div>A[]\nB</div>`,
skipIf: useBR,
},
{
init: `<div>A[]</div><div>B</div>`,
},
{
init: `<div>A<div>[]B</div></div>`,
},
{
init: `<div>A[]<div>B</div></div>`,
},
{
init: `<div><div>A[]</div>B</div>`,
},
{
init: `<div><div>A</div>[]B</div>`,
},
{
init: `<div>A[]<ul><li>B</li></ul></div>`,
},
{
init: `<div>A[]<ul><li>B</li><li>C</li></ul></div>`,
},
{
init: `<ul><li>[]A</li></ul>`,
},
{
init: `<ul><li>A[]</li><li>B</li></ul>`,
},
{
init: `<ul><li>A</li><li>[]B</li></ul>`,
},
{
init: `<ul><li>[]A</li><li>B</li></ul>`,
},
{
init: `<div>A[]<ol><li>B</li></ol></div>`,
},
{
init: `<div>A[]<ol><li>B</li><li>C</li></ol></div>`,
},
{
init: `<ol><li>[]A</li></ol>`,
},
{
init: `<ol><li>A[]</li><li>B</li></ol>`,
},
{
init: `<ol><li>A</li><li>[]B</li></ol>`,
},
{
init: `<ol><li>[]A</li><li>B</li></ol>`,
},
{
init: `<div>A[]<dl><dt>B</dt></dl></div>`,
},
{
init: `<div>A[]<dl><dt>B</dt><dt>C</dt></dl></div>`,
},
{
init: `<div>A[]<dl><dt>B</dt><dd>C</dd></dl></div>`,
},
{
init: `<div>A[]<dl><dd>B</dd></dl></div>`,
},
{
init: `<div>A[]<dl><dd>B</dd><dt>C</dt></dl></div>`,
},
{
init: `<div>A[]<dl><dd>B</dd><dd>C</dd></dl></div>`,
},
{
init: `<dl><dt>A[]</dt><dt>B</dt></ol>`,
},
{
init: `<dl><dd>A[]</dd><dt>B</dt></ol>`,
},
{
init: `<dl><dt>A[]</dt><dd>B</dd></ol>`,
},
{
init: `<dl><dd>A[]</dd><dd>B</dd></ol>`,
},
{
init: `<table><tr><td>A[]</td><td>B</td></tr></table>`,
},
{
init: `<table><tr><td>A[]</td></tr><tr><td>B</td></tr></table>`,
},
{
init: `<table><tr><th>A[]</th><td>B</td></tr></table>`,
},
{
init: `<table><tr><th>A[]</th></tr><tr><td>B</td></tr></table>`,
},
{
init: `<table><tr><td>A[]</td><th>B</th></tr></table>`,
},
{
init: `<table><tr><td>A[]</td></tr><tr><th>B</th></tr></table>`,
},
{
init: `<table><tr><th>A[]</th><th>B</th></tr></table>`,
},
{
init: `<table><tr><th>A[]</th></tr><tr><th>B</th></tr></table>`,
},
]) {
if (data.skipIf !== undefined && data.skipIf) {
continue;
}
test(() => {
utilsForRichText.setupEditingHost(data.init);
document.execCommand("forwardDelete");
const richTextResult = richTextEditingHost.innerHTML;
utilsForPlainText.setupEditingHost(data.init);
document.execCommand("forwardDelete");
const plainTextResult = plainTextEditingHost.innerHTML;
assert_equals(plainTextResult, richTextResult);
}, `document.execCommand("forwardDelete") when ${data.init}`);
}
}, {once: true});
</script>
</head>
<body>
<div contenteditable="true"></div>
<div contenteditable="plaintext-only"></div>
</body>
</html>