import 'dart:io'; import 'package:famedlysdk/famedlysdk.dart'; import 'package:fluffychat/components/adaptive_page_layout.dart'; import 'package:fluffychat/components/content_banner.dart'; import 'package:fluffychat/components/matrix.dart'; import 'package:fluffychat/utils/app_route.dart'; import 'package:fluffychat/views/chat_list.dart'; import 'package:fluffychat/views/login.dart'; import 'package:flutter/foundation.dart'; import 'package:flutter/material.dart'; import 'package:image_picker/image_picker.dart'; import 'package:toast/toast.dart'; class SettingsView extends StatelessWidget { @override Widget build(BuildContext context) { return AdaptivePageLayout( primaryPage: FocusPage.SECOND, firstScaffold: ChatList(), secondScaffold: Settings(), ); } } class Settings extends StatefulWidget { @override _SettingsState createState() => _SettingsState(); } class _SettingsState extends State { Future profileFuture; dynamic profile; void logoutAction(BuildContext context) async { MatrixState matrix = Matrix.of(context); Navigator.of(context).pushAndRemoveUntil( AppRoute.defaultRoute(context, LoginPage()), (r) => false); await matrix.tryRequestWithLoadingDialog(matrix.client.logout()); matrix.clean(); } void setDisplaynameAction(BuildContext context, String displayname) async { final MatrixState matrix = Matrix.of(context); final Map success = await matrix.tryRequestWithLoadingDialog( matrix.client.connection.jsonRequest( type: HTTPType.PUT, action: "/client/r0/profile/${matrix.client.userID}/displayname", data: {"displayname": displayname}, ), ); if (success != null && success.length == 0) { Toast.show( "Displayname has been changed", context, duration: Toast.LENGTH_LONG, ); setState(() { profileFuture = null; profile = null; }); } } void setAvatarAction(BuildContext context) async { final File tempFile = await ImagePicker.pickImage( source: ImageSource.gallery, imageQuality: 50, maxWidth: 1600, maxHeight: 1600); if (tempFile == null) return; final MatrixState matrix = Matrix.of(context); final Map success = await matrix.tryRequestWithLoadingDialog( matrix.client.setAvatar( MatrixFile( bytes: await tempFile.readAsBytes(), path: tempFile.path, ), ), ); if (success != null && success.length == 0) { Toast.show( "Avatar has been changed", context, duration: Toast.LENGTH_LONG, ); setState(() { profileFuture = null; profile = null; }); } } @override Widget build(BuildContext context) { final Client client = Matrix.of(context).client; profileFuture ??= client.getProfileFromUserId(client.userID); profileFuture.then((p) => setState(() => profile = p)); return Scaffold( appBar: AppBar( title: Text("Settings"), ), body: ListView( children: [ ContentBanner( profile?.avatarUrl ?? MxContent(""), defaultIcon: Icons.account_circle, loading: profile == null, ), kIsWeb ? Container() : ListTile( title: Text("Upload avatar"), trailing: Icon(Icons.file_upload), onTap: () => setAvatarAction(context), ), ListTile( trailing: Icon(Icons.edit), title: TextField( readOnly: profile == null, textInputAction: TextInputAction.done, onSubmitted: (s) => setDisplaynameAction(context, s), decoration: InputDecoration( border: InputBorder.none, labelText: "Edit displayname", labelStyle: TextStyle(color: Colors.black), hintText: (profile?.displayname ?? ""), ), ), ), ListTile( trailing: Icon(Icons.exit_to_app), title: Text("Logout"), onTap: () => logoutAction(context), ), ], ), ); } }