This is a sample flutter onboarding plugin you use to attract first-time users when they land on your page, hence the name onboarding. You can implement this widget anyhow you want in your app, by managing its top-level state to show the widget to users at the appropriate time. There are also many parameters that enable you to design this widget to your liking.
sdk: ">=2.12.0 <3.0.0"
flutter: ">=1.17.0"
To start using this widget, you will need to first import the package inside your project following the installation guide found on peb.dev/packages/onboarding.
dependencies:
onboarding: ^3.0.0+
$ flutter pub get
Please note that versions bellow V3.0.0 will not be supported anymore. Please consider upgrading to V3.0.0+. The new changes offer more customization and flexibility to developers with many functionalities. All the functionalities from previous versions are also included plus more.
Sample examples will be shown bellow from left to right respectively.
To use this widget,
import 'package:onboarding/onboarding.dart';
inside your dart file- Follow the example found at the
main.dart
of the example and implement it in your app.
class MyApp extends StatefulWidget {
const MyApp({Key? key}) : super(key: key);
@override
State<MyApp> createState() => _MyAppState();
}
class _MyAppState extends State<MyApp> {
late Material materialButton;
final onboardingPagesList = [
PageModel(
widget: Column(
children: [
Padding(
padding: const EdgeInsets.symmetric(
horizontal: 45.0,
vertical: 90.0,
),
child: Image.asset('assets/images/facebook.png',
color: pageImageColor),
),
Container(
padding: const EdgeInsets.symmetric(horizontal: 45.0),
alignment: Alignment.centerLeft,
child: const Text(
'SECURED BACKUP',
style: pageTitleStyle,
textAlign: TextAlign.left,
),
),
Container(
padding:
const EdgeInsets.symmetric(horizontal: 45.0, vertical: 10.0),
alignment: Alignment.centerLeft,
child: const Text(
'Keep your files in closed safe so you can\'t lose them. Consider TrueNAS.',
style: pageInfoStyle,
textAlign: TextAlign.left,
),
),
],
),
),
PageModel(
widget: Column(
children: [
Padding(
padding: const EdgeInsets.symmetric(
horizontal: 45.0,
vertical: 90.0,
),
child:
Image.asset('assets/images/twitter.png', color: pageImageColor),
),
Container(
padding: const EdgeInsets.symmetric(horizontal: 45.0),
alignment: Alignment.centerLeft,
child: const Text(
'CHANGE AND RISE',
style: pageTitleStyle,
textAlign: TextAlign.left,
),
),
Container(
padding:
const EdgeInsets.symmetric(horizontal: 45.0, vertical: 10.0),
alignment: Alignment.centerLeft,
child: const Text(
'Give others access to any file or folders you choose',
style: pageInfoStyle,
textAlign: TextAlign.left,
),
),
],
),
),
PageModel(
widget: Column(
children: [
Padding(
padding: const EdgeInsets.symmetric(
horizontal: 45.0,
vertical: 90.0,
),
child: Image.asset('assets/images/instagram.png',
color: pageImageColor),
),
Container(
padding: const EdgeInsets.symmetric(horizontal: 45.0),
alignment: Alignment.centerLeft,
child: const Text(
'EASY ACCESS',
style: pageTitleStyle,
textAlign: TextAlign.left,
),
),
Container(
padding:
const EdgeInsets.symmetric(horizontal: 45.0, vertical: 10.0),
alignment: Alignment.centerLeft,
child: const Text(
'Reach your files anytime from any devices anywhere',
style: pageInfoStyle,
textAlign: TextAlign.left,
),
),
],
),
),
];
@override
void initState() {
super.initState();
materialButton = _skipButton;
}
void _buildButton(int pageIndex) {
if (pageIndex == 2) {
setState(() {
materialButton = _signupButton;
});
} else {
setState(() {
materialButton = _skipButton;
});
}
}
Material get _skipButton {
return Material(
borderRadius: defaultSkipButtonBorderRadius,
color: defaultSkipButtonColor,
child: InkWell(
borderRadius: defaultSkipButtonBorderRadius,
onTap: () {},
child: const Padding(
padding: defaultSkipButtonPadding,
child: Text(
'Skip',
style: defaultSkipButtonTextStyle,
),
),
),
);
}
Material get _signupButton {
return Material(
borderRadius: defaultProceedButtonBorderRadius,
color: defaultProceedButtonColor,
child: InkWell(
borderRadius: defaultProceedButtonBorderRadius,
onTap: () {},
child: const Padding(
padding: defaultProceedButtonPadding,
child: Text(
'Sign up',
style: defaultProceedButtonTextStyle,
),
),
),
);
}
@override
Widget build(BuildContext context) {
return MaterialApp(
debugShowCheckedModeBanner: false,
title: 'Flutter Demo',
theme: ThemeData(
primarySwatch: Colors.blue,
visualDensity: VisualDensity.adaptivePlatformDensity,
),
home: Onboarding(
pages: onboardingPagesList,
onPageChange: (int pageIndex) {
_buildButton(pageIndex);
},
footer: Footer(
child: materialButton,
indicator: Indicator(
indicatorDesign: IndicatorDesign.line(
lineDesign: LineDesign(
lineType: DesignType.line_uniform,
),
),
),
footerPadding: const EdgeInsets.all(45.0),
),
),
);
}
}
Sample examples of using different indicator types
indicator: Indicator(
indicatorDesign: IndicatorDesign.line(
lineDesign: LineDesign(
lineType: DesignType.line_uniform,
),
),
)
indicator: Indicator(
indicatorDesign: IndicatorDesign.line(
lineDesign: LineDesign(
lineType: DesignType.line_nonuniform,
),
),
)
indicator: Indicator(
indicatorDesign: IndicatorDesign.polygon(
polygonDesign: PolygonDesign(
polygon: DesignType.polygon_arrow,
),
),
)
indicator: Indicator(
indicatorDesign: IndicatorDesign.polygon(
polygonDesign: PolygonDesign(
polygon: DesignType.polygon_circle,
),
),
)
indicator: Indicator(
indicatorDesign: IndicatorDesign.polygon(
polygonDesign: PolygonDesign(
polygon: DesignType.polygon_diamond,
),
),
)
indicator: Indicator(
indicatorDesign: IndicatorDesign.polygon(
polygonDesign: PolygonDesign(
polygon: DesignType.polygon_pentagon,
),
),
)
indicator: Indicator(
indicatorDesign: IndicatorDesign.polygon(
polygonDesign: PolygonDesign(
polygon: DesignType.polygon_square,
polygonSpacer: 14.0
),
),
)