Highlighted selection - not to lose focus when focusing on other element on the page #4963
Replies: 7 comments 4 replies
-
| I'm interested in this as well. I have a similar use case, how I want to solve it for now is that I apply a mark extension (like highlight) to the selection and I make sure to remove it when I'm done with these other steps. But I'm not very happy with this approach because it has a lot of pitfalls, like preserving these marks to the db, not removing them correctly, etc. | 
Beta Was this translation helpful? Give feedback.
-
| @demiro @abecirovic3 Hi, Is there a solution to this problem? | 
Beta Was this translation helpful? Give feedback.
-
| found this code and updated it a bit and it seems to work fine  | 
Beta Was this translation helpful? Give feedback.
-
| I had the same issue and found a way to fix it! The key is to only show the decoration when the editor loses focus, and let the browser's selection color take over when focused. Here's what worked for me: const SelectionDecoration = Extension.create({
  name: 'selectionDecoration',
  addOptions() {
    return {
      className: 'selection',
    }
  },
  addProseMirrorPlugins() {
    return [
      new Plugin({
        key: new PluginKey('selection'),
        props: {
          decorations: (state) => {
            const { selection } = state
            const { focused } = this.editor
            // Skip decoration if editor is focused or no selection
            if (focused || selection.empty) {
              return null
            }
            return DecorationSet.create(state.doc, [
              Decoration.inline(selection.from, selection.to, {
                class: this.options.className,
              }),
            ])
          },
        },
      }),
    ]
  },
}) | 
Beta Was this translation helpful? Give feedback.
-
| This is a very common use case in canvas style llms - suspect it will keep cropping up. Would be good to find a way to make this in built | 
Beta Was this translation helpful? Give feedback.
-
| To keep system colors you can use these css values: background: Highlight;
color: HighlightText; | 
Beta Was this translation helpful? Give feedback.
-
| I'm also upping this with the rise of llms and such it is definitely a necessary core feature | 
Beta Was this translation helpful? Give feedback.
Uh oh!
There was an error while loading. Please reload this page.
-
I know it sounds a bit confusing...
but inherently the selection get lost when you focus on another element
imagine this scenario:
user selects some text
clicks on a chatbot window and ask the bot something related to the selection
obviously as soon as you click into checkbox window, the editor's selection gets lost.... but, is it possible to wrap the whole selection in a special ..., and when I select something else, it gets unwrapped?
I saw some other editors do it, not sure how would I go about it in tiptap? Is there an extension or command that would do that?
Beta Was this translation helpful? Give feedback.
All reactions