dynamic_rail 0.0.4
dynamic_rail: ^0.0.4 copied to clipboard
A Flutter project that implements a dynamic rail widget.
example/lib/main.dart
import 'package:dynamic_rail/dynamic_rail.dart';
import 'package:flutter/material.dart';
void main() {
runApp(const MyApp());
}
class MyApp extends StatelessWidget {
const MyApp({Key? key}) : super(key: key);
@override
Widget build(BuildContext context) {
return MaterialApp(
title: 'YouTube Player Embed Demo',
home: DynamicRailTest(),
debugShowCheckedModeBanner: false,
);
}
}
class DynamicRailTest extends StatefulWidget {
const DynamicRailTest({super.key});
@override
State<DynamicRailTest> createState() => _DynamicRailTestState();
}
class _DynamicRailTestState extends State<DynamicRailTest> {
bool isRailOpen = false;
@override
Widget build(BuildContext context) {
return Scaffold(
body: DynamicRail(
isRailOpen: isRailOpen,
icon: Icon(
isRailOpen ? Icons.close : Icons.menu,
color: Colors.black,
),
railWidth: 45,
onPress: () {
setState(() {
isRailOpen = !isRailOpen;
});
},
child: Column(
children: [
IconButton(
icon: Icon(Icons.home),
onPressed: () {
setState(() {
// Toggle the rail open state
});
},
),
IconButton(
icon: Icon(Icons.search),
onPressed: () {
setState(() {
// Toggle the rail open state
});
},
),
IconButton(
icon: Icon(Icons.favorite),
onPressed: () {
setState(() {
// Toggle the rail open state
});
},
),
IconButton(
icon: Icon(Icons.settings),
onPressed: () {
setState(() {
// Toggle the rail open state
});
},
),
],
)),
);
}
}