invoice/lib/ui/app/scrollable_listview.dart

53 lines
1.3 KiB
Dart

import 'package:flutter/material.dart';
class ScrollableListView extends StatefulWidget {
const ScrollableListView({
Key key,
@required this.children,
this.scrollController,
this.padding,
}) : super(key: key);
final List<Widget> children;
final ScrollController scrollController;
final EdgeInsetsGeometry padding;
@override
_ScrollableListViewState createState() => _ScrollableListViewState();
}
class _ScrollableListViewState extends State<ScrollableListView> {
ScrollController _scrollController;
bool _isHovered = false;
@override
void initState() {
super.initState();
_scrollController = ScrollController();
}
@override
void dispose() {
_scrollController.dispose();
super.dispose();
}
@override
Widget build(BuildContext context) {
return MouseRegion(
onEnter: (event) => setState(() => _isHovered = true),
onExit: (event) => setState(() => _isHovered = false),
child: Scrollbar(
child: ListView(
padding: widget.padding,
children: widget.children,
controller: widget.scrollController ?? _scrollController,
shrinkWrap: true,
),
controller: widget.scrollController ?? _scrollController,
isAlwaysShown: _isHovered,
),
);
}
}