enhance_stepper 0.0.1  enhance_stepper: ^0.0.1 copied to clipboard
enhance_stepper: ^0.0.1 copied to clipboard
add alternate labels to the stepper in flutter;add step icon change.
enhance_stepper #
An easy to implement Extra features.
- add alternate labels to the stepper in flutter.
- add step icon change.
EnhanceStepper(
    stepIconSize: 30,
    //...
    steps: tuples.map((e) => EnhanceStep(
      circleChild: Icon(e.item1, color: Colors.blue, size: 30,),
    //...
    isStepperTypeHorizontalBottom: true,
    isStepperTypeHorizontalBottomLineFollowIconMidY: true,
    //...
);
Screenshots #


Getting Started #
This project is a starting point for a Dart package, a library module containing code that can be shared easily across multiple Flutter or Dart projects.
For help getting started with Flutter, view our online documentation, which offers tutorials, samples, guidance on mobile development, and a full API reference.
Usage #
To use this package, add cupertino_stepper as a dependency in your pubspec.yaml file.
Example #
class MyHomePage extends StatefulWidget {
  MyHomePage({Key? key, required this.title}) : super(key: key);
  final String title;
  @override
  _MyHomePageState createState() => _MyHomePageState();
}
class _MyHomePageState extends State<MyHomePage> {
  int groupValue = 0;
  
  StepperType _type = StepperType.vertical;
  List<Tuple2> tuples = [
    Tuple2(Icons.directions_bike, StepState.indexed, ),
    Tuple2(Icons.directions_bus, StepState.editing, ),
    Tuple2(Icons.directions_railway, StepState.complete, ),
    Tuple2(Icons.directions_boat, StepState.disabled, ),
    Tuple2(Icons.directions_car, StepState.error, ),
  ];
  int _index = 0;
  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: Text(widget.title),
        actions: [
          TextButton(onPressed: (){
            DDLog("change");
            setState(() {
              _type = _type == StepperType.vertical ? StepperType.horizontal : StepperType.vertical;
            });
          }, child: Icon(Icons.change_circle_outlined, color: Colors.white,)),
        ],
      ),
      body: buildStepperCustom(context),
    );
  }
  void go(int index) {
    if (index == -1 && _index <= 0 ) {
      DDLog("it's first Step!");
      return;
    }
    if (index == 1 && _index >= tuples.length - 1) {
      DDLog("it's last Step!");
      return;
    }
    setState(() {
      _index += index;
    });
  }
  Widget buildStepperCustom(BuildContext context) {
    return EnhanceStepper(
        stepIconSize: 30,
        type: _type,
        currentStep: _index,
        physics: ClampingScrollPhysics(),
        steps: tuples.map((e) => EnhanceStep(
          circleChild: Icon(e.item1, color: Colors.blue, size: 30,),
          state: StepState.values[tuples.indexOf(e)],
          isActive: _index == tuples.indexOf(e),
          isStepperTypeHorizontalBottom: true,
          isStepperTypeHorizontalBottomLineFollowIconMidY: true,
          title: Text("step ${tuples.indexOf(e)}"),
          subtitle: Text("${e.item2.toString().split(".").last}",),
          content: Text("Content for Step ${tuples.indexOf(e)}"),
        )).toList(),
        onStepCancel: () {
          go(-1);
        },
        onStepContinue: () {
          go(1);
        },
        onStepTapped: (index) {
          DDLog(index);
          setState(() {
            _index = index;
          });
        },
        controlsBuilder: (BuildContext context, { VoidCallback? onStepContinue, VoidCallback? onStepCancel }){
          return Row(
            children: [
              SizedBox(height: 30,),
              ElevatedButton(
                onPressed: onStepContinue,
                child: Text("Next"),
              ),
              SizedBox(width: 8,),
              TextButton(onPressed: onStepCancel, child: Text("Back"), ),
            ],
          );
        }
    );
  }
}