Skip to content

Commit

Permalink
Show example of a workaround for Chrome bug that puts cursor in wrong…
Browse files Browse the repository at this point in the history
… place (ianstormtaylor#4772)

There is a Chromium bug where, if you have an inline at the end of a block,
clicking the end of a block puts the cursor inside the inline
instead of inside the final {text: ''} node.

This commit updates the inlines example to show the problem, and to show
a known workaround for the problem.

See for context: ianstormtaylor#4704
  • Loading branch information
jameshfisher authored and DougReeder committed Apr 3, 2022
1 parent 41f1939 commit 174555a
Showing 1 changed file with 33 additions and 1 deletion.
34 changes: 33 additions & 1 deletion site/examples/inlines.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -47,8 +47,16 @@ const initialValue: Descendant[] = [
children: [
{
text:
'There are two ways to add links. You can either add a link via the toolbar icon above, or if you want in on a little secret, copy a URL to your keyboard and paste it while a range of text is selected.',
'There are two ways to add links. You can either add a link via the toolbar icon above, or if you want in on a little secret, copy a URL to your keyboard and paste it while a range of text is selected. ',
},
// The following is an example of an inline at the end of a block.
// This is an edge case that can cause issues.
{
type: 'link',
url: 'https://twitter.com/JustMissEmma/status/1448679899531726852',
children: [{ text: 'Finally, here is our favorite dog video.' }],
},
{ text: '' },
],
},
]
Expand Down Expand Up @@ -96,6 +104,7 @@ const InlinesExample = () => {
</Toolbar>
<Editable
renderElement={props => <Element {...props} />}
renderLeaf={props => <Text {...props} />}
placeholder="Enter some text..."
onKeyDown={onKeyDown}
/>
Expand Down Expand Up @@ -291,6 +300,29 @@ const Element = props => {
}
}

const Text = props => {
const { attributes, children, leaf } = props
return (
<span
// The following is a workaround for a Chromium bug where,
// if you have an inline at the end of a block,
// clicking the end of a block puts the cursor inside the inline
// instead of inside the final {text: ''} node
// https://github.com/ianstormtaylor/slate/issues/4704#issuecomment-1006696364
className={
leaf.text === ''
? css`
padding-left: 0.1px;
`
: null
}
{...attributes}
>
{children}
</span>
)
}

const AddLinkButton = () => {
const editor = useSlate()
return (
Expand Down

0 comments on commit 174555a

Please sign in to comment.