Tutorial and code of Stepper in Flutter. Copy and paste the below code as per your requirements.
cupertino_stepper: ^0.2.1
import 'package:flutter/cupertino.dart';
import 'package:cupertino_stepper/cupertino_stepper.dart';
void main() => runApp(const StepperApp());
class StepperApp extends StatelessWidget {
const StepperApp({Key? key}) : super(key: key);
@override
Widget build(BuildContext context) {
return const CupertinoApp(
title: 'Stepper',
debugShowCheckedModeBanner: false,
home: StepperPage(),
);
}
}
class StepperPage extends StatefulWidget {
const StepperPage({Key? key}) : super(key: key);
@override
_StepperPageState createState() => _StepperPageState();
}
class _StepperPageState extends State<StepperPage> {
int currentStep = 0;
@override
Widget build(BuildContext context) {
return CupertinoPageScaffold(
navigationBar: const CupertinoNavigationBar(
middle: Text('Stepper'),
),
child: SafeArea(
child: OrientationBuilder(
builder: (BuildContext context, Orientation orientation) {
switch (orientation) {
case Orientation.portrait:
return _buildStepper(StepperType.vertical);
case Orientation.landscape:
return _buildStepper(StepperType.horizontal);
default:
throw UnimplementedError(orientation.toString());
}
},
),
),
);
}
CupertinoStepper _buildStepper(StepperType type) {
final canCancel = currentStep > 0;
final canContinue = currentStep < 3;
return CupertinoStepper(
type: type,
currentStep: currentStep,
onStepTapped: (step) => setState(() => currentStep = step),
onStepCancel: canCancel ? () => setState(() => --currentStep) : null,
onStepContinue: canContinue ? () => setState(() => ++currentStep) : null,
steps: [
for (var i = 0; i < 3; ++i)
_buildStep(
title: Text('Step ${i + 1}'),
isActive: i == currentStep,
state: i == currentStep
? StepState.editing
: i < currentStep ? StepState.complete : StepState.indexed,
),
_buildStep(
title: const Text('Error'),
state: StepState.error,
),
_buildStep(
title: const Text('Disabled'),
state: StepState.disabled,
)
],
);
}
Step _buildStep({
required Widget title,
StepState state = StepState.indexed,
bool isActive = false,
}) {
return Step(
title: title,
subtitle: const Text('Subtitle'),
state: state,
isActive: isActive,
content: LimitedBox(
maxWidth: 300,
maxHeight: 300,
child: Container(color: CupertinoColors.systemGrey),
),
);
}
}