Merge pull request #111 from yaso-meth/QOL--Package-Body-Slide-Animation

Slide Animation of Tool Body
This commit is contained in:
yaso-meth
2025-03-18 12:45:06 +02:00
committed by GitHub

View File

@@ -1,7 +1,7 @@
import 'package:Mzansi_Innovation_Hub/mih_components/mih_package/mih_app_action.dart'; import 'package:Mzansi_Innovation_Hub/mih_components/mih_package/mih_app_action.dart';
import 'package:Mzansi_Innovation_Hub/mih_components/mih_package/mih_app_tools.dart'; import 'package:Mzansi_Innovation_Hub/mih_components/mih_package/mih_app_tools.dart';
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import 'package:flutter_swipe_detector/flutter_swipe_detector.dart'; // import 'package:flutter_swipe_detector/flutter_swipe_detector.dart';
// ignore: must_be_immutable // ignore: must_be_immutable
class MihApp extends StatefulWidget { class MihApp extends StatefulWidget {
@@ -9,7 +9,7 @@ class MihApp extends StatefulWidget {
final MihAppTools appTools; final MihAppTools appTools;
final List<Widget> appBody; final List<Widget> appBody;
int selectedbodyIndex; int selectedbodyIndex;
final onIndexChange; final Function(int) onIndexChange;
MihApp({ MihApp({
super.key, super.key,
required this.appActionButton, required this.appActionButton,
@@ -24,6 +24,32 @@ class MihApp extends StatefulWidget {
} }
class _MihAppState extends State<MihApp> { class _MihAppState extends State<MihApp> {
late PageController _pageController;
@override
void dispose() {
super.dispose();
_pageController.dispose();
}
@override
void didUpdateWidget(covariant MihApp oldWidget) {
super.didUpdateWidget(oldWidget);
if (oldWidget.selectedbodyIndex != widget.selectedbodyIndex) {
_pageController.animateToPage(
widget.selectedbodyIndex,
duration: const Duration(milliseconds: 300),
curve: Curves.easeInOut,
);
}
}
@override
void initState() {
super.initState();
_pageController = PageController(initialPage: widget.selectedbodyIndex);
}
@override @override
Widget build(BuildContext context) { Widget build(BuildContext context) {
Size screenSize = MediaQuery.of(context).size; Size screenSize = MediaQuery.of(context).size;
@@ -45,34 +71,49 @@ class _MihAppState extends State<MihApp> {
], ],
), ),
Expanded( Expanded(
child: SwipeDetector( child: PageView.builder(
onSwipeLeft: (offset) { controller: _pageController,
if (widget.selectedbodyIndex < itemCount: widget.appBody.length,
widget.appTools.tools.length - 1) { itemBuilder: (context, index) {
return widget.appBody[index];
},
onPageChanged: (index) {
setState(() { setState(() {
widget.selectedbodyIndex += 1; widget.selectedbodyIndex = index;
widget.onIndexChange(widget.selectedbodyIndex); widget.onIndexChange(widget.selectedbodyIndex);
}); });
}
// print("swipe left");
}, },
onSwipeRight: (offset) {
if (widget.selectedbodyIndex > 0) {
setState(() {
widget.selectedbodyIndex -= 1;
widget.onIndexChange(widget.selectedbodyIndex);
});
}
// print("swipe right");
},
child: Row(
children: [
Expanded(
child: widget.appBody[widget.selectedbodyIndex],
)
],
), ),
)), ),
// Expanded(
// child: SwipeDetector(
// onSwipeLeft: (offset) {
// if (widget.selectedbodyIndex <
// widget.appTools.tools.length - 1) {
// setState(() {
// widget.selectedbodyIndex += 1;
// widget.onIndexChange(widget.selectedbodyIndex);
// });
// }
// // print("swipe left");
// },
// onSwipeRight: (offset) {
// if (widget.selectedbodyIndex > 0) {
// setState(() {
// widget.selectedbodyIndex -= 1;
// widget.onIndexChange(widget.selectedbodyIndex);
// });
// }
// // print("swipe right");
// },
// child: Row(
// children: [
// Expanded(
// child: widget.appBody[widget.selectedbodyIndex],
// )
// ],
// ),
// )),
], ],
), ),
), ),