Files
fcs/lib/pages/signin/signup_page.dart

130 lines
3.6 KiB
Dart
Raw Normal View History

2020-10-07 02:33:06 +06:30
import 'package:fcs/pages/main/model/main_model.dart';
import 'package:fcs/pages/main/util.dart';
import 'package:fcs/pages/widgets/local_text.dart';
import 'package:fcs/pages/widgets/progress.dart';
2020-10-14 13:54:42 +06:30
import 'package:flutter/cupertino.dart';
2020-05-29 16:14:17 +06:30
import 'package:flutter/material.dart';
import 'package:flutter/services.dart';
import 'package:font_awesome_flutter/font_awesome_flutter.dart';
2020-09-04 01:42:58 +06:30
import 'package:provider/provider.dart';
2020-05-29 16:14:17 +06:30
2020-09-04 15:30:10 +06:30
import '../../helpers/theme.dart';
2020-05-29 16:14:17 +06:30
2020-08-30 21:26:37 +06:30
class SignupPage extends StatefulWidget {
2020-05-29 16:14:17 +06:30
@override
2020-08-30 21:26:37 +06:30
_SignupPageState createState() => _SignupPageState();
2020-05-29 16:14:17 +06:30
}
2020-08-30 21:26:37 +06:30
class _SignupPageState extends State<SignupPage> {
2020-05-29 16:14:17 +06:30
bool _isLoading = false;
2021-09-10 12:02:08 +06:30
TextEditingController nameCtl = new TextEditingController();
2020-05-29 16:14:17 +06:30
@override
void initState() {
super.initState();
nameCtl = new TextEditingController();
}
@override
Widget build(BuildContext context) {
return LocalProgress(
inAsyncCall: _isLoading,
child: new Scaffold(
appBar: AppBar(
2020-06-01 14:24:45 +06:30
centerTitle: true,
leading: new IconButton(
2020-10-14 13:54:42 +06:30
icon: new Icon(
CupertinoIcons.back,
),
2020-06-01 14:24:45 +06:30
onPressed: () => Navigator.of(context).pop(),
),
2020-05-29 16:14:17 +06:30
backgroundColor: primaryColor,
),
body: _buildBody(context),
),
);
}
Widget _buildBody(BuildContext context) {
return ListView(
2020-06-01 14:24:45 +06:30
padding: EdgeInsets.only(top: 5, left: 10, right: 10),
2020-05-29 16:14:17 +06:30
children: <Widget>[
Container(
padding: EdgeInsets.only(top: 40),
child: LocalText(
context,
'user_edit.welcome',
fontSize: 21,
2020-06-01 14:24:45 +06:30
color: primaryColor,
2020-05-29 16:14:17 +06:30
fontWeight: FontWeight.bold,
),
),
Container(
padding: EdgeInsets.only(top: 25),
child: LocalText(
context,
'user_edit.name',
color: labelColor,
fontSize: 16,
),
),
Container(
2020-06-01 14:24:45 +06:30
padding: EdgeInsets.only(top: 0, bottom: 10),
2020-05-29 16:14:17 +06:30
child: TextFormField(
controller: nameCtl,
cursorColor: primaryColor,
textAlign: TextAlign.left,
2020-06-01 14:24:45 +06:30
keyboardType: TextInputType.text,
autofocus: true,
2020-05-29 16:14:17 +06:30
style: TextStyle(
fontSize: 18,
),
2020-06-01 14:24:45 +06:30
decoration: new InputDecoration(
enabledBorder: UnderlineInputBorder(
borderSide: BorderSide(color: primaryColor, width: 1.0)),
focusedBorder: UnderlineInputBorder(
borderSide: BorderSide(color: primaryColor, width: 1.0)),
2020-05-29 16:14:17 +06:30
),
)),
SizedBox(
height: 20,
),
Container(
child: Row(
mainAxisAlignment: MainAxisAlignment.end,
children: <Widget>[
InkWell(
onTap: () => _submit(),
child: CircleAvatar(
minRadius: 25,
backgroundColor: primaryColor,
child: Icon(
FontAwesomeIcons.check,
color: Colors.white,
),
),
)
],
),
),
],
);
}
2020-05-31 15:00:11 +06:30
_submit() async {
2020-09-13 21:49:39 +06:30
setState(() {
_isLoading = true;
});
try {
2020-09-17 06:02:48 +06:30
await context.read<MainModel>().joinInvite(nameCtl.text);
2020-09-13 21:49:39 +06:30
Navigator.pushNamedAndRemoveUntil(context, "/home", (r) => false);
} catch (e) {
showMsgDialog(context, "Error", e.toString());
} finally {
setState(() {
_isLoading = false;
});
}
2020-05-31 15:00:11 +06:30
}
2020-05-29 16:14:17 +06:30
}