-
-
Notifications
You must be signed in to change notification settings - Fork 687
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
MultiLineTextInput widget persistently takes on rich formatting on a paste operation #2957
Comments
Confirming this definitely isn't the intended behavior. I'm guessing we've missed an option when configuring the native text widgets. Not sure if this also affects GTK, iOS or Android; seems highly plausible it might be an issue on GTK. |
As least so far as MacOS goes, this seems to prevent MultiLineTextInput from taking rich-formatted text on a paste:
See https://developer.apple.com/documentation/appkit/nstextview/1449538-richtext. |
For Windows, it doesn't seem like you can disable rich text in the Winforms RichTextBox entirely, but intercepting and handling a CTRL-V to only take the plain text seems to work:
This isn't as general as the MacOS solution in my prior comment because the box still takes rich text, and this only handles placing rich text into the box via CTRL-V. Still, a MultiLineTextInput widget doesn't appear to accept drag-and-drop on Windows, so this may be sufficient. Another case to consider may be if a user provides a UI-based paste option (e.g., Edit > Paste), so perhaps there is another paste event that would need to be intercepted to cover that. |
In my quick testing, this does not appear to be an issue for GTK. It also does not appear to be an issue for iOS and Android—at least when pasting from macOS into an emulator, I haven't tested it natively. |
Looking at the implementation - the underlying widget is a RichTextBox, which is likely why there aren't any options to disable rich text. I did find this answer on StackOverflow which suggests a possible method for configuring a RichTextBox by poking the underlying win32 API to disable some mode settings on the widget. If you want to tinker with this approach, TextInput has an existing usage of SendMessage to trigger some internal logic around placeholders.
At least at present, we haven't got a default paste menu item for Windows (although perhaps we should); so this isn't an immediate issue; but agreed that a "generic" solution not directly tied to the keyboard handler would be preferable. |
Every text box on Windows has a right-click context menu with a Paste command, which is affected by this issue as well. |
Describe the bug
When pasting rich-formatted text into a MultiLineTextInput widget, the widget takes on the rich formatting.
Steps to reproduce
Expected behavior
While rich formatting may be desirable in some situations, I'd expect the default behavior to be displaying only plain text, like a TextInput widget.
Screenshots
Before paste:
Rich text (TextEdit):
After paste:
After clear:
Environment
Operating System:
Python version:
Software versions:
Logs
Additional context
No response
The text was updated successfully, but these errors were encountered: