You cannot select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
	
	
		
			181 lines
		
	
	
		
			7.6 KiB
		
	
	
	
		
			Dart
		
	
			
		
		
	
	
			181 lines
		
	
	
		
			7.6 KiB
		
	
	
	
		
			Dart
		
	
| import 'package:fluffychat/config/themes.dart';
 | |
| import 'package:fluffychat/l10n/l10n.dart';
 | |
| import 'package:fluffychat/pages/intro/intro_page_view_model.dart';
 | |
| import 'package:fluffychat/widgets/layouts/login_scaffold.dart';
 | |
| import 'package:fluffychat/widgets/matrix.dart';
 | |
| import 'package:flutter/material.dart';
 | |
| import 'package:flutter_linkify/flutter_linkify.dart';
 | |
| import 'package:url_launcher/url_launcher_string.dart';
 | |
| 
 | |
| class IntroPage extends StatelessWidget {
 | |
|   final bool addMultiAccount;
 | |
|   const IntroPage({this.addMultiAccount = false, super.key});
 | |
| 
 | |
|   @override
 | |
|   Widget build(BuildContext context) {
 | |
|     final theme = Theme.of(context);
 | |
|     return IntroPageViewModel(
 | |
|       builder: (context, state) {
 | |
|         return LoginScaffold(
 | |
|           enforceMobileMode: Matrix.of(context)
 | |
|               .widget
 | |
|               .clients
 | |
|               .any((client) => client.isLogged()),
 | |
|           appBar: AppBar(
 | |
|             centerTitle: true,
 | |
|             title: Text(
 | |
|               addMultiAccount
 | |
|                   ? L10n.of(context).addAccount
 | |
|                   : L10n.of(context).login,
 | |
|             ),
 | |
|             actions: [
 | |
|               PopupMenuButton<MoreLoginActions>(
 | |
|                 useRootNavigator: true,
 | |
|                 onSelected: state.onMoreAction,
 | |
|                 itemBuilder: (_) => [
 | |
|                   PopupMenuItem(
 | |
|                     value: MoreLoginActions.loginWithMxid,
 | |
|                     child: Row(
 | |
|                       mainAxisSize: MainAxisSize.min,
 | |
|                       children: [
 | |
|                         const Icon(Icons.login_outlined),
 | |
|                         const SizedBox(width: 12),
 | |
|                         Text(L10n.of(context).loginWithMatrixId),
 | |
|                       ],
 | |
|                     ),
 | |
|                   ),
 | |
|                   PopupMenuItem(
 | |
|                     value: MoreLoginActions.importBackup,
 | |
|                     child: Row(
 | |
|                       mainAxisSize: MainAxisSize.min,
 | |
|                       children: [
 | |
|                         const Icon(Icons.import_export_outlined),
 | |
|                         const SizedBox(width: 12),
 | |
|                         Text(L10n.of(context).hydrate),
 | |
|                       ],
 | |
|                     ),
 | |
|                   ),
 | |
|                   PopupMenuItem(
 | |
|                     value: MoreLoginActions.privacy,
 | |
|                     child: Row(
 | |
|                       mainAxisSize: MainAxisSize.min,
 | |
|                       children: [
 | |
|                         const Icon(Icons.privacy_tip_outlined),
 | |
|                         const SizedBox(width: 12),
 | |
|                         Text(L10n.of(context).privacy),
 | |
|                       ],
 | |
|                     ),
 | |
|                   ),
 | |
|                   PopupMenuItem(
 | |
|                     value: MoreLoginActions.about,
 | |
|                     child: Row(
 | |
|                       mainAxisSize: MainAxisSize.min,
 | |
|                       children: [
 | |
|                         const Icon(Icons.info_outlined),
 | |
|                         const SizedBox(width: 12),
 | |
|                         Text(L10n.of(context).about),
 | |
|                       ],
 | |
|                     ),
 | |
|                   ),
 | |
|                 ],
 | |
|               ),
 | |
|             ],
 | |
|           ),
 | |
|           body: LayoutBuilder(
 | |
|             builder: (context, constraints) {
 | |
|               return SingleChildScrollView(
 | |
|                 child: ConstrainedBox(
 | |
|                   constraints: BoxConstraints(minHeight: constraints.maxHeight),
 | |
|                   child: IntrinsicHeight(
 | |
|                     child: Column(
 | |
|                       children: [
 | |
|                         // display a prominent banner to import session for TOR browser
 | |
|                         // users. This feature is just some UX sugar as TOR users are
 | |
|                         // usually forced to logout as TOR browser is non-persistent
 | |
|                         AnimatedContainer(
 | |
|                           height: state.isTorBrowser ? 64 : 0,
 | |
|                           duration: FluffyThemes.animationDuration,
 | |
|                           curve: FluffyThemes.animationCurve,
 | |
|                           clipBehavior: Clip.hardEdge,
 | |
|                           decoration: const BoxDecoration(),
 | |
|                           child: Material(
 | |
|                             clipBehavior: Clip.hardEdge,
 | |
|                             borderRadius: const BorderRadius.vertical(
 | |
|                               bottom: Radius.circular(8),
 | |
|                             ),
 | |
|                             color: theme.colorScheme.surface,
 | |
|                             child: ListTile(
 | |
|                               leading: const Icon(Icons.vpn_key),
 | |
|                               title: Text(L10n.of(context).hydrateTor),
 | |
|                               subtitle: Text(L10n.of(context).hydrateTorLong),
 | |
|                               trailing:
 | |
|                                   const Icon(Icons.chevron_right_outlined),
 | |
|                               onTap: () {},
 | |
|                             ),
 | |
|                           ),
 | |
|                         ),
 | |
|                         Container(
 | |
|                           alignment: Alignment.center,
 | |
|                           padding: const EdgeInsets.symmetric(horizontal: 8.0),
 | |
|                           child: Hero(
 | |
|                             tag: 'info-logo',
 | |
|                             child: Image.asset(
 | |
|                               './assets/banner_transparent.png',
 | |
|                               fit: BoxFit.fitWidth,
 | |
|                             ),
 | |
|                           ),
 | |
|                         ),
 | |
|                         const SizedBox(height: 32),
 | |
|                         Padding(
 | |
|                           padding: const EdgeInsets.symmetric(horizontal: 32.0),
 | |
|                           child: SelectableLinkify(
 | |
|                             text: L10n.of(context).appIntroduction,
 | |
|                             textScaleFactor:
 | |
|                                 MediaQuery.textScalerOf(context).scale(1),
 | |
|                             textAlign: TextAlign.center,
 | |
|                             linkStyle: TextStyle(
 | |
|                               color: theme.colorScheme.secondary,
 | |
|                               decorationColor: theme.colorScheme.secondary,
 | |
|                             ),
 | |
|                             onOpen: (link) => launchUrlString(link.url),
 | |
|                           ),
 | |
|                         ),
 | |
|                         const Spacer(),
 | |
|                         Padding(
 | |
|                           padding: const EdgeInsets.all(32.0),
 | |
|                           child: Column(
 | |
|                             mainAxisSize: MainAxisSize.min,
 | |
|                             crossAxisAlignment: CrossAxisAlignment.stretch,
 | |
|                             children: [
 | |
|                               ElevatedButton(
 | |
|                                 style: ElevatedButton.styleFrom(
 | |
|                                   backgroundColor: theme.colorScheme.primary,
 | |
|                                   foregroundColor: theme.colorScheme.onPrimary,
 | |
|                                 ),
 | |
|                                 onPressed: state.createNewAccount,
 | |
|                                 child: Text(L10n.of(context).createNewAccount),
 | |
|                               ),
 | |
|                               const SizedBox(height: 16),
 | |
|                               ElevatedButton(
 | |
|                                 style: ElevatedButton.styleFrom(),
 | |
|                                 onPressed: state.loginToExistingAccount,
 | |
|                                 child: Text(
 | |
|                                   L10n.of(context).loginWithExistingAccount,
 | |
|                                 ),
 | |
|                               ),
 | |
|                             ],
 | |
|                           ),
 | |
|                         ),
 | |
|                       ],
 | |
|                     ),
 | |
|                   ),
 | |
|                 ),
 | |
|               );
 | |
|             },
 | |
|           ),
 | |
|         );
 | |
|       },
 | |
|     );
 | |
|   }
 | |
| }
 |