Skip to content

Instantly share code, notes, and snippets.

@BbsonLin
Last active October 31, 2023 08:54
Show Gist options
  • Save BbsonLin/472f481cb95c2c58d4558f6b7d1c414c to your computer and use it in GitHub Desktop.
Save BbsonLin/472f481cb95c2c58d4558f6b7d1c414c to your computer and use it in GitHub Desktop.
Flutter showDialog with return value
import 'package:flutter/material.dart';
final Color darkBlue = Color.fromARGB(255, 18, 32, 47);
void main() {
runApp(MyApp());
}
class MyApp extends StatelessWidget {
@override
Widget build(BuildContext context) {
return MaterialApp(
theme: ThemeData.dark().copyWith(scaffoldBackgroundColor: darkBlue),
debugShowCheckedModeBanner: false,
home: Home(),
);
}
}
class Home extends StatefulWidget {
@override
_HomeState createState() => _HomeState();
}
class _HomeState extends State<Home> {
TextEditingController _controller = TextEditingController();
String inputString = "";
@override
Widget build(BuildContext context) {
return Scaffold(
body: Center(
child: Column(
mainAxisAlignment: MainAxisAlignment.center,
children: <Widget>[
Text(inputString),
RaisedButton(
child: Text("Show Dialog"),
onPressed: () {
showDialog(
context: context,
builder: (BuildContext context) {
return AlertDialog(
title: Text("Setting String"),
content: TextFormField(
controller: _controller,
),
actions: <Widget>[
FlatButton(
child: Text("OK"),
onPressed: () {
Navigator.pop(context, _controller.text);
},
)
],
);
},
).then((val) {
setState(() {
inputString = val;
});
});
},
),
],
),
),
);
}
}
@BbsonLin
Copy link
Author

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment