I have a complex layout that uses Slivers and when a TextField is focused, it is hidden beneath the KeyboardActionsItem.
import 'package:flutter/material.dart';
import 'package:flutter/services.dart';
import 'package:keyboard_actions/keyboard_actions.dart';
void main() => runApp(const MyApp());
class MyApp extends StatelessWidget {
const MyApp({super.key});
@override
Widget build(BuildContext context) {
return MaterialApp(
title: 'Flutter Demo',
debugShowCheckedModeBanner: false,
theme: ThemeData(
colorScheme: ColorScheme.fromSeed(seedColor: Colors.deepPurple),
useMaterial3: true,
),
home: const MyHomePage(title: 'Flutter Demo Home Page'),
);
}
}
class MyHomePage extends StatefulWidget {
final String title;
const MyHomePage({
Key? key,
required this.title,
}) : super(key: key);
@override
State<MyHomePage> createState() => _MyHomePageState();
}
class _MyHomePageState extends State<MyHomePage> {
late FocusNode node;
final _keyItemAutoscroll = GlobalKey();
@override
void initState() {
node = FocusNode();
super.initState();
}
@override
void dispose() {
node.dispose();
super.dispose();
}
KeyboardActionsConfig _buildConfig(BuildContext context) {
return KeyboardActionsConfig(
keyboardActionsPlatform: KeyboardActionsPlatform.ALL,
keyboardBarColor: Colors.grey[200],
nextFocus: false,
actions: [
KeyboardActionsItem(
focusNode: node,
toolbarButtons: [
(node) {
return GestureDetector(
onTap: () => node.unfocus(),
child: const Padding(
padding: EdgeInsets.all(8.0),
child: Text('Acept'),
),
);
}
],
),
],
);
}
@override
Widget build(BuildContext context) {
MediaQuery.of(context).removeViewInsets(removeBottom: true);
return Scaffold(
appBar: AppBar(
backgroundColor: Theme.of(context).colorScheme.inversePrimary,
title: Text(widget.title),
),
body: Padding(
padding: const EdgeInsets.only(bottom: 0),
child: CustomScrollView(
keyboardDismissBehavior: ScrollViewKeyboardDismissBehavior.onDrag,
cacheExtent: 250,
slivers: [
SliverToBoxAdapter(
child: Column(
children: [
...List.generate(
5,
(i) => Container(
height: 120,
color: Colors.primaries[i],
),
),
],
),
),
SliverToBoxAdapter(
child: Column(
children: [
KeyboardActions(
disableScroll: true,
overscroll: 0,
autoScroll: false,
bottomAvoiderScrollPhysics:
const NeverScrollableScrollPhysics(),
config: _buildConfig(context),
child: TextField(
key: _keyItemAutoscroll,
focusNode: node,
keyboardType: TextInputType.number,
inputFormatters: [
FilteringTextInputFormatter.allow(
RegExp(r'[0-9]'),
)
],
),
),
],
),
),
SliverToBoxAdapter(
child: Column(
children: [
...List.generate(
5,
(i) => Container(
height: 120,
color: Colors.primaries[i],
),
),
],
),
),
],
),
),
);
}
}
I have a complex layout that uses Slivers and when a TextField is focused, it is hidden beneath the KeyboardActionsItem.
I am using:
Example: