|
|
|
@ -17,26 +17,24 @@ class SettingsScreen extends StatefulWidget {
|
|
|
|
|
|
|
|
|
|
class _SettingsScreenState extends State<SettingsScreen> {
|
|
|
|
|
@override
|
|
|
|
|
Widget build(BuildContext context) {
|
|
|
|
|
return Scaffold(
|
|
|
|
|
body: SafeArea(
|
|
|
|
|
child: SingleChildScrollView(
|
|
|
|
|
child: Align(
|
|
|
|
|
alignment: Alignment.topCenter,
|
|
|
|
|
child: ConstrainedBox(
|
|
|
|
|
constraints: const BoxConstraints(maxWidth: 400),
|
|
|
|
|
child: const Card(
|
|
|
|
|
child: Padding(
|
|
|
|
|
padding: EdgeInsets.symmetric(vertical: 18, horizontal: 12),
|
|
|
|
|
child: SettingsContent(),
|
|
|
|
|
Widget build(BuildContext context) => Scaffold(
|
|
|
|
|
body: SafeArea(
|
|
|
|
|
child: SingleChildScrollView(
|
|
|
|
|
child: Align(
|
|
|
|
|
alignment: Alignment.topCenter,
|
|
|
|
|
child: ConstrainedBox(
|
|
|
|
|
constraints: const BoxConstraints(maxWidth: 400),
|
|
|
|
|
child: const Card(
|
|
|
|
|
child: Padding(
|
|
|
|
|
padding: EdgeInsets.symmetric(vertical: 18, horizontal: 12),
|
|
|
|
|
child: SettingsContent(),
|
|
|
|
|
),
|
|
|
|
|
),
|
|
|
|
|
),
|
|
|
|
|
),
|
|
|
|
|
),
|
|
|
|
|
),
|
|
|
|
|
),
|
|
|
|
|
);
|
|
|
|
|
}
|
|
|
|
|
);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
class SettingsContent extends StatelessWidget {
|
|
|
|
@ -45,57 +43,53 @@ class SettingsContent extends StatelessWidget {
|
|
|
|
|
}) : super(key: key);
|
|
|
|
|
|
|
|
|
|
@override
|
|
|
|
|
Widget build(BuildContext context) {
|
|
|
|
|
return Column(
|
|
|
|
|
children: [
|
|
|
|
|
...[
|
|
|
|
|
Text(
|
|
|
|
|
'Settings',
|
|
|
|
|
style: Theme.of(context).textTheme.headline4,
|
|
|
|
|
),
|
|
|
|
|
ElevatedButton(
|
|
|
|
|
onPressed: () {
|
|
|
|
|
BookstoreAuthScope.of(context)!.signOut();
|
|
|
|
|
},
|
|
|
|
|
child: const Text('Sign out'),
|
|
|
|
|
),
|
|
|
|
|
Link(
|
|
|
|
|
uri: Uri.parse('/book/0'),
|
|
|
|
|
builder: (context, followLink) {
|
|
|
|
|
return TextButton(
|
|
|
|
|
Widget build(BuildContext context) => Column(
|
|
|
|
|
children: [
|
|
|
|
|
...[
|
|
|
|
|
Text(
|
|
|
|
|
'Settings',
|
|
|
|
|
style: Theme.of(context).textTheme.headline4,
|
|
|
|
|
),
|
|
|
|
|
ElevatedButton(
|
|
|
|
|
onPressed: () {
|
|
|
|
|
BookstoreAuthScope.of(context)!.signOut();
|
|
|
|
|
},
|
|
|
|
|
child: const Text('Sign out'),
|
|
|
|
|
),
|
|
|
|
|
Link(
|
|
|
|
|
uri: Uri.parse('/book/0'),
|
|
|
|
|
builder: (context, followLink) => TextButton(
|
|
|
|
|
onPressed: followLink,
|
|
|
|
|
child: const Text('Go directly to /book/0 (Link)'),
|
|
|
|
|
);
|
|
|
|
|
},
|
|
|
|
|
),
|
|
|
|
|
),
|
|
|
|
|
),
|
|
|
|
|
TextButton(
|
|
|
|
|
child: const Text('Go directly to /book/0 (RouteState)'),
|
|
|
|
|
onPressed: () {
|
|
|
|
|
RouteStateScope.of(context)!.go('/book/0');
|
|
|
|
|
},
|
|
|
|
|
),
|
|
|
|
|
].map((w) => Padding(padding: const EdgeInsets.all(8), child: w)),
|
|
|
|
|
TextButton(
|
|
|
|
|
child: const Text('Go directly to /book/0 (RouteState)'),
|
|
|
|
|
onPressed: () {
|
|
|
|
|
RouteStateScope.of(context)!.go('/book/0');
|
|
|
|
|
},
|
|
|
|
|
),
|
|
|
|
|
].map((w) => Padding(padding: const EdgeInsets.all(8), child: w)),
|
|
|
|
|
TextButton(
|
|
|
|
|
onPressed: () => showDialog<String>(
|
|
|
|
|
context: context,
|
|
|
|
|
builder: (context) => AlertDialog(
|
|
|
|
|
title: const Text('Alert!'),
|
|
|
|
|
content: const Text('The alert description goes here.'),
|
|
|
|
|
actions: <Widget>[
|
|
|
|
|
TextButton(
|
|
|
|
|
onPressed: () => Navigator.pop(context, 'Cancel'),
|
|
|
|
|
child: const Text('Cancel'),
|
|
|
|
|
),
|
|
|
|
|
TextButton(
|
|
|
|
|
onPressed: () => Navigator.pop(context, 'OK'),
|
|
|
|
|
child: const Text('OK'),
|
|
|
|
|
),
|
|
|
|
|
],
|
|
|
|
|
onPressed: () => showDialog<String>(
|
|
|
|
|
context: context,
|
|
|
|
|
builder: (context) => AlertDialog(
|
|
|
|
|
title: const Text('Alert!'),
|
|
|
|
|
content: const Text('The alert description goes here.'),
|
|
|
|
|
actions: <Widget>[
|
|
|
|
|
TextButton(
|
|
|
|
|
onPressed: () => Navigator.pop(context, 'Cancel'),
|
|
|
|
|
child: const Text('Cancel'),
|
|
|
|
|
),
|
|
|
|
|
TextButton(
|
|
|
|
|
onPressed: () => Navigator.pop(context, 'OK'),
|
|
|
|
|
child: const Text('OK'),
|
|
|
|
|
),
|
|
|
|
|
],
|
|
|
|
|
),
|
|
|
|
|
),
|
|
|
|
|
),
|
|
|
|
|
child: const Text('Show Dialog'),
|
|
|
|
|
)
|
|
|
|
|
],
|
|
|
|
|
);
|
|
|
|
|
}
|
|
|
|
|
child: const Text('Show Dialog'),
|
|
|
|
|
)
|
|
|
|
|
],
|
|
|
|
|
);
|
|
|
|
|
}
|
|
|
|
|