Skip to content

Commit

Permalink
updated close method
Browse files Browse the repository at this point in the history
  • Loading branch information
ottodaempfle committed Mar 7, 2024
1 parent c6d4af4 commit 3779e56
Showing 1 changed file with 19 additions and 25 deletions.
44 changes: 19 additions & 25 deletions lib/scrollable_bottom_sheet.dart
Original file line number Diff line number Diff line change
Expand Up @@ -50,16 +50,14 @@ class ScrollableBottomSheet extends StatefulWidget {
}
}

class ScrollableBottomSheetState extends State<ScrollableBottomSheet>
with SingleTickerProviderStateMixin {
class ScrollableBottomSheetState extends State<ScrollableBottomSheet> with SingleTickerProviderStateMixin {
final _scrollController = ScrollController();
late AnimationController _animationController;
final _velocityTracker = VelocityTracker.withKind(PointerDeviceKind.touch);
var _scrollingEnabled = false;
var _isScrollingBlocked = false;

Tween<double> get _sizeTween =>
Tween(begin: widget.minHeight, end: widget.maxHeight);
Tween<double> get _sizeTween => Tween(begin: widget.minHeight, end: widget.maxHeight);

bool get _isPanelOpen => _animationController.value == 1.0;

Expand All @@ -74,9 +72,7 @@ class ScrollableBottomSheetState extends State<ScrollableBottomSheet>
_animationController = AnimationController(
vsync: this,
duration: widget.animationDuration,
value: widget.initialPosition == null
? 0.0
: _pixelToValue(widget.initialPosition!),
value: widget.initialPosition == null ? 0.0 : _pixelToValue(widget.initialPosition!),
)..addListener(_notifyScrollListeners);
}

Expand All @@ -89,22 +85,17 @@ class ScrollableBottomSheetState extends State<ScrollableBottomSheet>

@override
Widget build(BuildContext context) {
final borderRadius =
BorderRadius.vertical(top: Radius.circular(widget.borderRadiusTop));
final borderRadius = BorderRadius.vertical(top: Radius.circular(widget.borderRadiusTop));

return Listener(
onPointerDown: widget.canDrag
? (p) => _velocityTracker.addPosition(p.timeStamp, p.position)
: null,
onPointerDown: widget.canDrag ? (p) => _velocityTracker.addPosition(p.timeStamp, p.position) : null,
onPointerMove: widget.canDrag
? (p) {
_velocityTracker.addPosition(p.timeStamp, p.position);
_onDragUpdate(p.delta.dy);
}
: null,
onPointerUp: widget.canDrag
? (p) => _onGestureEnd(_velocityTracker.getVelocity())
: null,
onPointerUp: widget.canDrag ? (p) => _onGestureEnd(_velocityTracker.getVelocity()) : null,
child: MediaQuery.removePadding(
context: context,
removeTop: true,
Expand Down Expand Up @@ -133,8 +124,7 @@ class ScrollableBottomSheetState extends State<ScrollableBottomSheet>
);
},
child: Builder(
builder: (context) =>
widget.builder(context, _scrollController),
builder: (context) => widget.builder(context, _scrollController),
),
),
),
Expand All @@ -154,9 +144,7 @@ class ScrollableBottomSheetState extends State<ScrollableBottomSheet>
// if the panel is open and the user hasn't scrolled, we need to determine
// whether to enable scrolling if the user swipes up, or disable closing and
// begin to close the panel if the user swipes down
if (_isPanelOpen &&
_scrollController.hasClients &&
_scrollController.offset <= 0) {
if (_isPanelOpen && _scrollController.hasClients && _scrollController.offset <= 0) {
setState(() => _scrollingEnabled = dy < 0);
}

Expand Down Expand Up @@ -191,8 +179,7 @@ class ScrollableBottomSheetState extends State<ScrollableBottomSheet>
final dyVelocity = velocity.pixelsPerSecond.dy;
final visualVelocity = -dyVelocity / (widget.maxHeight - widget.minHeight);

final newPosition =
_findNearestRelativeSnapPoint(target: _animationController.value);
final newPosition = _findNearestRelativeSnapPoint(target: _animationController.value);

switch (newPosition) {
case 1.0:
Expand Down Expand Up @@ -229,7 +216,15 @@ class ScrollableBottomSheetState extends State<ScrollableBottomSheet>

// region panel options

Future<void> close() {
Future<void> close() async {
setState(() => _scrollingEnabled = false);

await _scrollController.animateTo(
0.0,
duration: widget.animationDuration,
curve: Curves.linear,
);

return _animationController.fling(velocity: -1.0);
}

Expand All @@ -238,8 +233,7 @@ class ScrollableBottomSheetState extends State<ScrollableBottomSheet>
}

Future<void> animateToNearestSnapPoint() {
final newPosition =
_findNearestRelativeSnapPoint(target: _animationController.value);
final newPosition = _findNearestRelativeSnapPoint(target: _animationController.value);
return animateTo(
pixels: _sizeTween.transform(newPosition),
duration: widget.animationDuration,
Expand Down

0 comments on commit 3779e56

Please sign in to comment.