import 'package:flutter/material.dart'; import 'app_state.dart'; import 'app_state_manager.dart'; import 'basic_text_field.dart'; import 'formatting_toolbar.dart'; import 'replacements.dart'; import 'text_editing_delta_history_view.dart'; void main() { runApp(const MyApp()); } class MyApp extends StatelessWidget { const MyApp({super.key}); @override Widget build(BuildContext context) { return AppStateWidget( child: MaterialApp( debugShowCheckedModeBanner: false, title: 'Simplistic Editor', theme: ThemeData( primarySwatch: Colors.blue, useMaterial3: true, ), home: const MyHomePage(title: 'Simplistic Editor'), ), ); } } class MyHomePage extends StatefulWidget { const MyHomePage({super.key, required this.title}); final String title; @override State createState() => _MyHomePageState(); } class _MyHomePageState extends State { late ReplacementTextEditingController _replacementTextEditingController; final FocusNode _focusNode = FocusNode(); @override void initState() { super.initState(); _replacementTextEditingController = ReplacementTextEditingController(); } @override void didChangeDependencies() { super.didChangeDependencies(); _replacementTextEditingController = AppStateManager.of(context).appState.replacementsController; } static Route _aboutDialogBuilder( BuildContext context, Object? arguments) { const String aboutContent = 'TextEditingDeltas are a new feature in the latest Flutter stable release that give the user' ' finer grain control over the changes that occur during text input. There are four types of' ' deltas: Insertion, Deletion, Replacement, and NonTextUpdate. To gain access to these TextEditingDeltas' ' you must implement DeltaTextInputClient, and set enableDeltaModel to true in the TextInputConfiguration.' ' Before Flutter only provided the TextInputClient, which does not provide a delta between the current' ' and previous text editing states. DeltaTextInputClient does provide these deltas, allowing the user to build' ' more powerful rich text editing applications such as this small example. This feature is supported on all platforms.'; return DialogRoute( context: context, builder: (context) => const AlertDialog( title: Center(child: Text('About')), content: Text(aboutContent), ), ); } @override Widget build(BuildContext context) { return Scaffold( appBar: AppBar( title: Text(widget.title), actions: [ IconButton( onPressed: () { Navigator.of(context).restorablePush(_aboutDialogBuilder); }, icon: const Icon(Icons.info_outline), ), ], ), body: Padding( padding: const EdgeInsets.all(16.0), child: Center( child: Column( children: [ const FormattingToolbar(), Expanded( child: Padding( padding: const EdgeInsets.symmetric(horizontal: 35.0), child: BasicTextField( controller: _replacementTextEditingController, style: const TextStyle( fontSize: 18.0, color: Colors.black, ), focusNode: _focusNode, ), ), ), const Expanded( child: TextEditingDeltaHistoryView(), ), ], ), ), ), ); } }