import 'package:cached_network_image/cached_network_image.dart'; import 'package:flutter/cupertino.dart'; import 'package:flutter/material.dart'; import 'package:flutter_hooks/flutter_hooks.dart'; import 'package:lemmy_api_client/lemmy_api_client.dart'; import 'package:url_launcher/url_launcher.dart' as ul; import '../hooks/stores.dart'; import '../widgets/bottom_modal.dart'; import '../widgets/fullscreenable_image.dart'; import 'add_instance.dart'; class AddAccountPage extends HookWidget { final String instanceUrl; const AddAccountPage({@required this.instanceUrl}) : assert(instanceUrl != null); @override Widget build(BuildContext context) { final theme = Theme.of(context); final usernameController = useTextEditingController(); final passwordController = useTextEditingController(); useValueListenable(usernameController); useValueListenable(passwordController); final accountsStore = useAccountsStore(); final loading = useState(false); final selectedInstance = useState(instanceUrl); final icon = useState(null); useMemoized(() async { final site = await LemmyApi(selectedInstance.value).v1.getSite(); icon.value = site.site.icon; }); selectInstance() async { final val = await showModalBottomSheet( backgroundColor: Colors.transparent, isScrollControlled: true, context: context, builder: (context) => BottomModal( title: 'select instance', child: Column(children: [ for (final i in accountsStore.users.keys) RadioListTile( value: i, groupValue: selectedInstance.value, onChanged: (val) { Navigator.of(context).pop(val); }, title: Text(i), ), ListTile( leading: Padding( padding: const EdgeInsets.all(8), child: Icon(Icons.add), ), title: Text('Add instance'), onTap: () async { final val = await showCupertinoModalPopup( context: context, builder: (context) => AddInstancePage(), ); Navigator.of(context).pop(val); }, ), ]), ), ); if (val != null) { selectedInstance.value = val; final site = await LemmyApi(val).v1.getSite(); icon.value = site.site.icon; } } handleOnAdd() async { try { loading.value = true; await accountsStore.addAccount( instanceUrl, usernameController.text, passwordController.text, ); } on Exception catch (err) { Scaffold.of(context).showSnackBar(SnackBar( content: Text(err.toString()), )); } loading.value = false; Navigator.of(context).pop(); } return Scaffold( appBar: AppBar( leading: CloseButton(), actionsIconTheme: theme.iconTheme, iconTheme: theme.iconTheme, textTheme: theme.textTheme, brightness: theme.brightness, centerTitle: true, title: Text('Add account'), backgroundColor: theme.canvasColor, shadowColor: Colors.transparent, ), bottomNavigationBar: BottomAppBar( color: Colors.transparent, elevation: 0, child: SafeArea( child: Row( children: [ Padding( padding: const EdgeInsets.all(15), child: FlatButton( shape: RoundedRectangleBorder( borderRadius: BorderRadius.circular(10), ), child: Text('Cancel'), onPressed: () => Navigator.of(context).pop(), ), ), ], ), ), ), body: Padding( padding: const EdgeInsets.all(15), child: ListView( children: [ if (icon.value == null) SizedBox(height: 150) else SizedBox( height: 150, child: FullscreenableImage( url: icon.value, child: CachedNetworkImage( imageUrl: icon.value, errorWidget: (_, __, ___) => Container(), ), ), ), FlatButton( onPressed: selectInstance, child: Row( mainAxisAlignment: MainAxisAlignment.center, children: [ Text(selectedInstance.value), Icon(Icons.arrow_drop_down), ], ), shape: RoundedRectangleBorder( borderRadius: BorderRadius.circular(10), ), ), TextField( autofocus: true, controller: usernameController, decoration: InputDecoration( isDense: true, contentPadding: EdgeInsets.symmetric(horizontal: 10, vertical: 10), border: OutlineInputBorder( borderRadius: BorderRadius.circular(10), ), labelText: 'Username or email', ), ), const SizedBox(height: 5), TextField( controller: passwordController, obscureText: true, decoration: InputDecoration( isDense: true, contentPadding: EdgeInsets.symmetric(horizontal: 10, vertical: 10), border: OutlineInputBorder( borderRadius: BorderRadius.circular(10), ), labelText: 'Password', ), ), RaisedButton( color: theme.accentColor, padding: EdgeInsets.all(0), shape: RoundedRectangleBorder( borderRadius: BorderRadius.circular(10), ), child: !loading.value ? Text('Sign in') : CircularProgressIndicator(), onPressed: usernameController.text.isEmpty || passwordController.text.isEmpty ? null : handleOnAdd, ), FlatButton( shape: RoundedRectangleBorder( borderRadius: BorderRadius.circular(10), ), child: Text('Register'), onPressed: () { ul.launch('https://$instanceUrl/login'); }, ), // Row( // // mainAxisAlignment: MainAxisAlignment.end, // children: [ // FlatButton( // shape: RoundedRectangleBorder( // borderRadius: BorderRadius.circular(10), // ), // child: Text('Cancel'), // onPressed: () => Navigator.of(context).pop(), // ), // Spacer(), // ], // ) ], ), ), ); } }