mirror of
https://github.com/ueberdosis/tiptap.git
synced 2024-11-24 19:59:02 +08:00
clean up and add attributes to the highlight command
This commit is contained in:
parent
47109ed97f
commit
c9da3ab269
@ -1,6 +1,8 @@
|
||||
# Highlight
|
||||
Use this extension to render highlighted text with `<mark>`. You can use only default `<mark>` HTML tag, which has a yellow background color by default, or apply different colors.
|
||||
|
||||
Type `==two equal signs==` and it will magically transform to <mark>highlighted</mark> text while you type.
|
||||
|
||||
## Installation
|
||||
```bash
|
||||
# With npm
|
||||
@ -16,9 +18,9 @@ yarn add @tiptap/extension-highlight
|
||||
| class | string | – | Add a custom class to the rendered HTML tag. |
|
||||
|
||||
## Commands
|
||||
| Command | Options | Description |
|
||||
| --------- | ------- | ------------------------- |
|
||||
| highlight | — | Mark text as highlighted. |
|
||||
| Command | Options | Description |
|
||||
| --------- | ------- | ----------------------------------------------------------- |
|
||||
| highlight | color | Mark text as highlighted, optionally pass a specific color. |
|
||||
|
||||
## Keyboard shortcuts
|
||||
* Windows/Linux: `Control` `E`
|
||||
@ -28,4 +30,4 @@ yarn add @tiptap/extension-highlight
|
||||
[packages/extension-highlight/](https://github.com/ueberdosis/tiptap-next/blob/main/packages/extension-highlight/)
|
||||
|
||||
## Usage
|
||||
<demo name="Extensions/Highlight" highlight="3-5,17,36" />
|
||||
<demo name="Extensions/Highlight" highlight="3-8,48,67" />
|
||||
|
@ -8,10 +8,9 @@ import markIsActive from '../utils/markIsActive'
|
||||
export const ToggleMark = createExtension({
|
||||
addCommands() {
|
||||
return {
|
||||
toggleMark: (typeOrName: string | MarkType): Command => ({ state, dispatch }) => {
|
||||
toggleMark: (typeOrName: string | MarkType, attrs?: {}): Command => ({ state, dispatch, commands }) => {
|
||||
const type = getMarkType(typeOrName, state.schema)
|
||||
|
||||
/* TODO:
|
||||
const hasMarkWithDifferentAttributes = attrs
|
||||
&& markIsActive(state, type)
|
||||
&& !markIsActive(state, type, attrs)
|
||||
@ -20,7 +19,6 @@ export const ToggleMark = createExtension({
|
||||
// @ts-ignore
|
||||
return commands.updateMark(type, attrs)
|
||||
}
|
||||
*/
|
||||
|
||||
return originalToggleMark(type)(state, dispatch)
|
||||
},
|
||||
|
@ -17,7 +17,6 @@ const Highlight = createMark({
|
||||
color: {
|
||||
default: null,
|
||||
parseHTML: element => {
|
||||
console.log(element.getAttribute('data-color'))
|
||||
return {
|
||||
color:
|
||||
element.getAttribute('data-color')
|
||||
@ -45,11 +44,6 @@ const Highlight = createMark({
|
||||
},
|
||||
{
|
||||
style: 'background-color',
|
||||
// getAttrs: value => {
|
||||
// return {
|
||||
// color: value,
|
||||
// }
|
||||
// },
|
||||
},
|
||||
]
|
||||
},
|
||||
@ -61,7 +55,7 @@ const Highlight = createMark({
|
||||
addCommands() {
|
||||
return {
|
||||
highlight: (attrs?: HighlightOptions): Command => ({ commands }) => {
|
||||
return commands.toggleMark('highlight')
|
||||
return commands.toggleMark('highlight', attrs)
|
||||
},
|
||||
}
|
||||
},
|
||||
|
Loading…
Reference in New Issue
Block a user