From 1f75f3738bedf9668fb6dcf16d1a7d568e0abd9f Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Wiktor=20Obr=C4=99bski?= Date: Thu, 21 Nov 2024 21:39:33 +0100 Subject: [PATCH] Improve TextArea documentation --- docs/dev/Lua API.rst | 25 ++++++++++++++++++++----- 1 file changed, 20 insertions(+), 5 deletions(-) diff --git a/docs/dev/Lua API.rst b/docs/dev/Lua API.rst index ebe4fc6c84..65209a0770 100644 --- a/docs/dev/Lua API.rst +++ b/docs/dev/Lua API.rst @@ -5589,14 +5589,29 @@ TextArea Functions: * ``textarea:scrollToCursor()`` Scrolls the text area view to ensure that the current cursor position is visible. - This is useful for automatically scrolling when the user moves the cursor - beyond the visible region of the text area. + This happens automatically when the user interactively moves the cursor or + pastes text into the widget, but may need to be called when ``setCursor`` is + called programmatically. * ``textarea:clearHistory()`` Clear undo/redo history of the widget. -Functionality: +Functionality +------------- + +The TextArea widget provides a familiar and intuitive text editing experience with baseline features such as: + +- Text Wrapping: Automatically fits text within the display area. +- Mouse and Keyboard Support: Standard keys like :kbd:`Home`, :kbd:`End`, :kbd:`Backspace`, and :kbd:`Delete` are supported, + along with gestures like double-click to select a word or triple-click to select a line. +- Clipboard Operations: copy, cut, and paste, + with intuitive defaults when no text is selected. +- Undo/Redo: :kbd:`Ctrl` + :kbd:`Z` and :kbd:`Ctrl` + :kbd:`Y` for quick changes. +- Additional features include advanced navigation, line management, + and smooth scrolling for handling long text efficiently. + +Detailed list: - Cursor Control: Navigate through text using arrow keys (Left, Right, Up, and Down) for precise cursor placement. @@ -5606,6 +5621,8 @@ Functionality: moving up or down, making vertical navigation more intuitive. - Mouse Control: Use the mouse to position the cursor within the text, providing an alternative to keyboard navigation. +- Text Selection: Select text with the mouse, with support for replacing or + removing selected text. - New Lines: Easily insert new lines using the :kbd:`Enter` key, supporting multiline text input. - Text Wrapping: Text automatically wraps within the editor, ensuring lines fit @@ -5621,8 +5638,6 @@ Functionality: the end of the line. - Delete Last Word: :kbd:`Ctrl` + :kbd:`W` removes the word immediately before the cursor. -- Text Selection: Select text with the mouse, with support for replacing or - removing selected text. - Jump to Beginning/End: Quickly move the cursor to the beginning or end of the text using :kbd:`Ctrl` + :kbd:`Home` and :kbd:`Ctrl` + :kbd:`End`. - Select Word/Line: Use double click to select current word, or triple click to