formatus 2.1.0
formatus: ^2.1.0 copied to clipboard
Formatus - The plain Flutter Rich-Text-Editor for all platforms
FORMATUS #
A plain Flutter Rich-Text-Editor without any dependencies
Features #
- Runs on all platforms
- Small and easy to use
- Directly integrates into
TextFieldandTextFormField - No dependencies to other packages to keep it small and lightweight
- Supports multiple section and inline formats
- Includes a viewer for the formatted text
FormatusBarprovides multiple callbacks to integrate your favorite packages
Getting started #
Add the latest version of Formatus to the pubspec.yaml file:
flutter:
formatus: ^2.1.0
Follow these steps:
- create a
FormatusController - create a
FocusNode - supply both
FormatusControllerandFocusNodeto theFormatusBarand theTextField
Usage #
Use Formatus like this:
FocusNode _formatusFocus = FocusNode(debugLabel: 'formatus');
late FormatusController controller;
String savedText = '';
void initState() {
controller = FormatusController( formattedText: savedText,
onChanged: (v) => setState(() => savedText = v ),);
}
Widget build(BuildContext context) => Column( children: [
FormatusBar(
controller: controller,
hideInactive: true,
textFieldFocus: _formatusFocus,
),
TextFormField(
controller: controller,
focusNode: _formatusFocus,
minLines: 3,
maxLines: 10 ),
]);
//--- Don't forget the standard dispose of the controller
void dispose() {
controller.dispose();
}
Emojis #
Formatus has an action emoji. The button will become available as soon as an
emoji selector callback is provided to FormatusBar. If only a small number
of emojis is required then this approach is sufficient:
FormatusBar( ...,
onSelectEmoji: (context) async => await showDialog<String>(
context: context, builder: (context) => Dialog(
child: Wrap( children: ['😀', '🚀', '✅'].map( (e) => IconButton(
icon: Text(e), onPressed: () => Navigator.pop(context, e),
), ).toList(), ), ), ),
A full emoji package like emoji_picker_flutter can also be integrated easily:
FormatusBar( ...,
onSelectEmoji: (context) => showEmojiSelector(), );
Future<String?> showEmojiSelector() async =>
showAdaptiveDialog(context: context, builder: (BuildContext context) =>
Dialog( child: EmojiPicker(textEditingController: controller, ), ), );
FAQ #
- Q: I can only enter one line of text. Enter does not work.
A: Supply
minLines: 2or a larger value toTextFormField
Supported Formats #
- H1 → Header 1 with largest font size
- H2 → Header 2 with larger font size
- H3 → Header 3 with large font size
- P → Paragraph with standard font size
- OL → Ordered list
- UL → Unordered list
- B → bold text
- I → italicized text
- U → underlined text
- S → strike-through text
- sub → subscript text
- sup → superscript text
- color → text coloring
🔗 Project Links #
- 🌐 Homepage
- 🐛 Issue Tracker
- 📚 Documentation
- 🗂️ Repository
Enhancements #
- implement undo / redo functionality
- parse Markdown format as input
- optimize formatting tree by reshaking
For an additional enhancement request please open an issue.
Known Deficiencies #
- Horizontal ruler not yet implemented
- Coloring is restricted to 19 included colors
- Line-breaks in pasted text are replaced by spaces
- Lists cannot be nested
- Subscript and superscript are displayed correctly only in [FormatusViewer] because Flutter [TextField] and [TextFormField] do not support their editing
User Manual #
Definition of Terms #
Caret : visible display of the cursor position
Format : All text has a format. Its format is specified by the section format and all inline formats applied to the text
Section : All text belongs to a section. Each section has a format. Multiple sections are separated by a newline
Use cases #
This section describes the use cases for Formatus.
- Position caret → updates
FormatusBarwith formats at caret position - Select a text range → updates
FormatusBarwith formats from selection start - Activate another section-format in
FormatusBar→ the current section (defined by caret position or start of a selected text-range) will be changed to the activated section-format - Change an inline-format in
FormatusBar→ if a text range is selected then the selected text will be updated with the new format - Enter characters (via keyboard or by pasting from a clipboard) → characters will be inserted at caret position. Current format settings will be applied
- Delete characters → if this includes one or more (requires a text-range) line-breaks then the text right of the deleted text will be integrated into the top-level node at deletion start
- Display the formatted text with
FormatusViewer
Additional information #
Please find additional information like architecture considerations at https://www.djarjo.com/formatus
If you encounter any issues or have ideas for some enhancements please open a ticket at https://github.com/hlemcke/formatus