-
-
Notifications
You must be signed in to change notification settings - Fork 4.3k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Add bind:text and bind:html support for contenteditable elements
Fixes #310
- Loading branch information
Showing
12 changed files
with
192 additions
and
6 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,43 @@ | ||
export default { | ||
props: { | ||
name: '<b>world</b>', | ||
}, | ||
|
||
html: ` | ||
<editor><b>world</b></editor> | ||
<p>hello <b>world</b></p> | ||
`, | ||
|
||
ssrHtml: ` | ||
<editor contenteditable="true"><b>world</b></editor> | ||
<p>hello <b>world</b></p> | ||
`, | ||
|
||
async test({ assert, component, target, window }) { | ||
const el = target.querySelector('editor'); | ||
assert.equal(el.innerHTML, '<b>world</b>'); | ||
|
||
el.innerHTML = 'every<span>body</span>'; | ||
|
||
// No updates to data yet | ||
assert.htmlEqual(target.innerHTML, ` | ||
<editor>every<span>body</span></editor> | ||
<p>hello <b>world</b></p> | ||
`); | ||
|
||
// Handle user input | ||
const event = new window.Event('input'); | ||
await el.dispatchEvent(event); | ||
assert.htmlEqual(target.innerHTML, ` | ||
<editor>every<span>body</span></editor> | ||
<p>hello every<span>body</span></p> | ||
`); | ||
|
||
component.name = 'good<span>bye</span>'; | ||
assert.equal(el.innerHTML, 'good<span>bye</span>'); | ||
assert.htmlEqual(target.innerHTML, ` | ||
<editor>good<span>bye</span></editor> | ||
<p>hello good<span>bye</span></p> | ||
`); | ||
}, | ||
}; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,6 @@ | ||
<script> | ||
export let name; | ||
</script> | ||
|
||
<editor contenteditable="true" bind:html={name}></editor> | ||
<p>hello {@html name}</p> |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,37 @@ | ||
export default { | ||
props: { | ||
name: 'world', | ||
}, | ||
|
||
html: ` | ||
<editor>world</editor> | ||
<p>hello world</p> | ||
`, | ||
|
||
ssrHtml: ` | ||
<editor contenteditable="true">world</editor> | ||
<p>hello world</p> | ||
`, | ||
|
||
async test({ assert, component, target, window }) { | ||
const el = target.querySelector('editor'); | ||
assert.equal(el.textContent, 'world'); | ||
|
||
const event = new window.Event('input'); | ||
|
||
el.textContent = 'everybody'; | ||
await el.dispatchEvent(event); | ||
|
||
assert.htmlEqual(target.innerHTML, ` | ||
<editor>everybody</editor> | ||
<p>hello everybody</p> | ||
`); | ||
|
||
component.name = 'goodbye'; | ||
assert.equal(el.textContent, 'goodbye'); | ||
assert.htmlEqual(target.innerHTML, ` | ||
<editor>goodbye</editor> | ||
<p>hello goodbye</p> | ||
`); | ||
}, | ||
}; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,6 @@ | ||
<script> | ||
export let name; | ||
</script> | ||
|
||
<editor contenteditable="true" bind:text={name}></editor> | ||
<p>hello {name}</p> |
15 changes: 15 additions & 0 deletions
15
test/validator/samples/contenteditable-dynamic/errors.json
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,15 @@ | ||
[{ | ||
"code": "dynamic-contenteditable-attribute", | ||
"message": "'contenteditable' attribute cannot be dynamic if element uses two-way binding", | ||
"start": { | ||
"line": 6, | ||
"column": 8, | ||
"character": 73 | ||
}, | ||
"end": { | ||
"line": 6, | ||
"column": 32, | ||
"character": 97 | ||
}, | ||
"pos": 73 | ||
}] |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,6 @@ | ||
<script> | ||
export let name; | ||
let toggle = false; | ||
</script> | ||
<editor contenteditable={toggle} bind:html={name}></editor> |
15 changes: 15 additions & 0 deletions
15
test/validator/samples/contenteditable-missing/errors.json
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,15 @@ | ||
[{ | ||
"code": "missing-contenteditable-attribute", | ||
"message": "'contenteditable' attribute is required for text and html two-way bindings", | ||
"start": { | ||
"line": 4, | ||
"column": 8, | ||
"character": 48 | ||
}, | ||
"end": { | ||
"line": 4, | ||
"column": 24, | ||
"character": 64 | ||
}, | ||
"pos": 48 | ||
}] |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,4 @@ | ||
<script> | ||
export let name; | ||
</script> | ||
<editor bind:text={name}></editor> |