flutter_reusablealerts 0.0.2 flutter_reusablealerts: ^0.0.2 copied to clipboard
A new Flutter project.
example/lib/main.dart
import 'package:flutter/cupertino.dart';
import 'package:flutter/material.dart';
import 'dart:async';
import 'package:flutter_reusablealerts/flutter_reusablealerts.dart';
void main() {
runApp(SampleAlertApp());
}
class SampleAlertApp extends StatelessWidget {
@override
Widget build(BuildContext context) {
return MaterialApp(
debugShowCheckedModeBanner: false,
home: Scaffold(
appBar: AppBar(
title: Text('Demo Alert'),
),
body: PopupDialog(),
),
);
}
}
class PopupDialog extends StatelessWidget {
@override
Widget build(BuildContext context) {
return Container(
child: Center(
child: Column(
mainAxisAlignment: MainAxisAlignment.center,
children: <Widget>[
ElevatedButton(
child: Text('Basic Alert'),
onPressed: () => _onBasicAlertPressed(context),
),
ElevatedButton(
child: Text('Custom Animation Alert'),
onPressed: () => _onCustomAnimationAlertPressed(context),
),
ElevatedButton(
child: Text('Alert with Button'),
onPressed: () => _onAlertButtonPressed(context),
),
ElevatedButton(
child: Text('Alert with Buttons'),
onPressed: () => _onAlertButtonsPressed(context),
),
ElevatedButton(
child: Text('Alert with Style'),
onPressed: () => _onAlertWithStylePressed(context),
),
ElevatedButton(
child: Text('Alert with Custom Image'),
onPressed: () => _onAlertWithCustomImagePressed(context),
),
ElevatedButton(
child: Text('Simple Bottom Alert '),
onPressed: () =>sampleBottomAlert(context),
)
],
),
),
);
}
_onBasicAlertPressed(context) {
Alert(
context: context,
title: "Demo",
desc: "Flutter is more awesome with Alert.",
).show();
}
// Code will continue after alert is closed.
_onBasicWaitingAlertPressed(context) async {
await Alert(
context: context,
title: "Demo",
desc: "Flutter is more awesome with Alert.",
).show();
// Code will continue after alert is closed.
debugPrint("Alert closed now.");
}
//Custom animation alert
_onCustomAnimationAlertPressed(context) {
Alert(
context: context,
title: "Demo",
desc: "Flutter is more awesome with Alert.",
alertAnimation: fadeAlertAnimation,
).show();
}
Widget fadeAlertAnimation(BuildContext context,
Animation<double> animation,
Animation<double> secondaryAnimation,
Widget child,) {
return Align(
child: FadeTransition(
opacity: animation,
child: child,
),
);
}
// Alert with single button.
_onAlertButtonPressed(context) {
Alert(
context: context,
type: AlertType.error,
title: "Demo",
desc: "Sample alert testing.",
buttons: [
DialogButton(
child: Text(
"Ok",
style: TextStyle(color: Colors.white, fontSize: 20),
),
onPressed: () =>Navigator.pop(context),
width: 120,
)
],
).show();
}
// Alert with multiple and custom buttons
_onAlertButtonsPressed(context) {
Alert(
context: context,
type: AlertType.warning,
title: "Exit",
desc: "Do you want to exit.",
buttons: [
DialogButton(
child: Text(
"YES",
style: TextStyle(color: Colors.white, fontSize: 18),
),
onPressed: () => Navigator.pop(context),
color: Color.fromRGBO(0, 179, 134, 1.0),
),
DialogButton(
child: Text(
"NO",
style: TextStyle(color: Colors.white, fontSize: 18),
),
onPressed: () => Navigator.pop(context),
gradient: LinearGradient(colors: [
Color.fromRGBO(116, 116, 191, 1.0),
Color.fromRGBO(52, 138, 199, 1.0),
]),
)
],
).show();
}
// Advanced using of alerts
_onAlertWithStylePressed(context) {
// Reusable alert style
var alertStyle = AlertStyle(
animationType: AnimationType.fromTop,
isCloseButton: false,
isOverlayTapDismiss: false,
descStyle: TextStyle(fontWeight: FontWeight.bold),
animationDuration: Duration(milliseconds: 400),
alertBorder: RoundedRectangleBorder(
borderRadius: BorderRadius.circular(0.0),
side: BorderSide(
color: Colors.grey,
),
),
titleStyle: TextStyle(
color: Colors.red,
),
constraints: BoxConstraints.expand(width: 300),
//First to chars "55" represents transparency of color
overlayColor: Color(0x55000000),
alertElevation: 0,
alertAlignment: Alignment.bottomCenter);
// Alert dialog using custom alert style
Alert(
context: context,
style: alertStyle,
type: AlertType.info,
title: "Delete",
desc: "You are deleting the item.",
buttons: [
DialogButton(
child: Text(
"Ok",
style: TextStyle(color: Colors.white, fontSize: 20),
),
onPressed: () => Navigator.pop(context),
color: Color.fromRGBO(0, 179, 134, 1.0),
radius: BorderRadius.circular(0.0),
),
],
).show();
}
// Alert custom images
_onAlertWithCustomImagePressed(context) {
Alert(
context: context,
title: "Alert",
desc: "Flutter Alert with image.",
image: Image.asset(
'$kImagePath/icon_success.png',
package: 'flutter_reusablealerts',
),
).show();
}
// Code will continue after alert is closed.
sampleBottomAlert(context) async {
var firstButtonText = 'Ok';
var secondButtonText = 'Cancel';
await Alert(
context: context,
title: "Exit",
desc: "Do you want to exit",
buttons: [
DialogButton(
child: Text(
"YES",
style: TextStyle(color: Colors.white, fontSize: 18),
),
onPressed: () => Navigator.pop(context),
color: Color.fromRGBO(0, 179, 134, 1.0),
),
DialogButton(
child: Text(
"NO",
style: TextStyle(color: Colors.white, fontSize: 18),
),
onPressed: () => Navigator.pop(context),
gradient: LinearGradient(colors: [
Color.fromRGBO(116, 116, 191, 1.0),
Color.fromRGBO(52, 138, 199, 1.0),
]),
)
],
).showBottomDialog(firstButtonText,secondButtonText);
// Code will continue after alert is closed.
debugPrint("Alert closed now.");
}
}