skip_log_in_screen.dart 6.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217
  1. import 'package:appflowy/core/frameless_window.dart';
  2. import 'package:appflowy/startup/entry_point.dart';
  3. import 'package:appflowy/startup/launch_configuration.dart';
  4. import 'package:appflowy/startup/startup.dart';
  5. import 'package:appflowy/user/application/auth/auth_service.dart';
  6. import 'package:dartz/dartz.dart' as dartz;
  7. import 'package:easy_localization/easy_localization.dart';
  8. import 'package:flowy_infra/size.dart';
  9. import 'package:flowy_infra_ui/flowy_infra_ui.dart';
  10. import 'package:appflowy_backend/dispatch/dispatch.dart';
  11. import 'package:appflowy_backend/log.dart';
  12. import 'package:appflowy_backend/protobuf/flowy-error/errors.pb.dart';
  13. import 'package:appflowy_backend/protobuf/flowy-folder2/protobuf.dart';
  14. import 'package:appflowy_backend/protobuf/flowy-user/user_profile.pb.dart';
  15. import 'package:flutter/material.dart';
  16. import 'package:google_fonts/google_fonts.dart';
  17. import 'package:url_launcher/url_launcher.dart';
  18. import '../../generated/locale_keys.g.dart';
  19. import 'folder/folder_widget.dart';
  20. import 'router.dart';
  21. import 'widgets/background.dart';
  22. class SkipLogInScreen extends StatefulWidget {
  23. final AuthRouter router;
  24. final AuthService authService;
  25. const SkipLogInScreen({
  26. Key? key,
  27. required this.router,
  28. required this.authService,
  29. }) : super(key: key);
  30. @override
  31. State<SkipLogInScreen> createState() => _SkipLogInScreenState();
  32. }
  33. class _SkipLogInScreenState extends State<SkipLogInScreen> {
  34. var _didCustomizeFolder = false;
  35. @override
  36. Widget build(BuildContext context) {
  37. return Scaffold(
  38. appBar: const _SkipLoginMoveWindow(),
  39. body: Center(
  40. child: _renderBody(context),
  41. ),
  42. );
  43. }
  44. Widget _renderBody(BuildContext context) {
  45. return Column(
  46. mainAxisAlignment: MainAxisAlignment.center,
  47. crossAxisAlignment: CrossAxisAlignment.center,
  48. children: [
  49. const Spacer(),
  50. FlowyLogoTitle(
  51. title: LocaleKeys.welcomeText.tr(),
  52. logoSize: const Size.square(40),
  53. ),
  54. const VSpace(32),
  55. GoButton(
  56. onPressed: () {
  57. if (_didCustomizeFolder) {
  58. _relaunchAppAndAutoRegister();
  59. } else {
  60. _autoRegister(context);
  61. }
  62. },
  63. ),
  64. const VSpace(32),
  65. SizedBox(
  66. width: MediaQuery.of(context).size.width * 0.5,
  67. child: FolderWidget(
  68. createFolderCallback: () async {
  69. _didCustomizeFolder = true;
  70. },
  71. ),
  72. ),
  73. const Spacer(),
  74. const VSpace(48),
  75. _buildSubscribeButtons(context),
  76. const VSpace(24),
  77. ],
  78. );
  79. }
  80. Widget _buildSubscribeButtons(BuildContext context) {
  81. return Row(
  82. mainAxisAlignment: MainAxisAlignment.center,
  83. children: [
  84. FlowyText.regular(
  85. LocaleKeys.youCanAlso.tr(),
  86. fontSize: FontSizes.s12,
  87. ),
  88. FlowyTextButton(
  89. LocaleKeys.githubStarText.tr(),
  90. fontWeight: FontWeight.w500,
  91. fontColor: Theme.of(context).colorScheme.primary,
  92. hoverColor: Colors.transparent,
  93. fillColor: Colors.transparent,
  94. onPressed: () => _launchURL(
  95. 'https://github.com/AppFlowy-IO/appflowy',
  96. ),
  97. ),
  98. FlowyText.regular(
  99. LocaleKeys.and.tr(),
  100. fontSize: FontSizes.s12,
  101. ),
  102. FlowyTextButton(
  103. LocaleKeys.subscribeNewsletterText.tr(),
  104. fontWeight: FontWeight.w500,
  105. fontColor: Theme.of(context).colorScheme.primary,
  106. hoverColor: Colors.transparent,
  107. fillColor: Colors.transparent,
  108. onPressed: () => _launchURL('https://www.appflowy.io/blog'),
  109. ),
  110. ],
  111. );
  112. }
  113. Future<void> _launchURL(String url) async {
  114. final uri = Uri.parse(url);
  115. if (await canLaunchUrl(uri)) {
  116. await launchUrl(uri);
  117. } else {
  118. throw 'Could not launch $url';
  119. }
  120. }
  121. Future<void> _autoRegister(BuildContext context) async {
  122. final result = await widget.authService.signUpAsGuest();
  123. result.fold(
  124. (error) {
  125. Log.error(error);
  126. },
  127. (user) {
  128. FolderEventGetCurrentWorkspace().send().then((result) {
  129. _openCurrentWorkspace(context, user, result);
  130. });
  131. },
  132. );
  133. }
  134. Future<void> _relaunchAppAndAutoRegister() async {
  135. await FlowyRunner.run(
  136. FlowyApp(),
  137. config: const LaunchConfiguration(
  138. autoRegistrationSupported: true,
  139. ),
  140. );
  141. }
  142. void _openCurrentWorkspace(
  143. BuildContext context,
  144. UserProfilePB user,
  145. dartz.Either<WorkspaceSettingPB, FlowyError> workspacesOrError,
  146. ) {
  147. workspacesOrError.fold(
  148. (workspaceSetting) {
  149. widget.router
  150. .pushHomeScreenWithWorkSpace(context, user, workspaceSetting);
  151. },
  152. (error) {
  153. Log.error(error);
  154. },
  155. );
  156. }
  157. }
  158. class GoButton extends StatelessWidget {
  159. final VoidCallback onPressed;
  160. const GoButton({
  161. super.key,
  162. required this.onPressed,
  163. });
  164. @override
  165. Widget build(BuildContext context) {
  166. return FlowyTextButton(
  167. LocaleKeys.letsGoButtonText.tr(),
  168. constraints: const BoxConstraints(
  169. maxWidth: 340,
  170. maxHeight: 48,
  171. ),
  172. radius: BorderRadius.circular(12),
  173. mainAxisAlignment: MainAxisAlignment.center,
  174. fontSize: FontSizes.s14,
  175. fontFamily: GoogleFonts.poppins(fontWeight: FontWeight.w500).fontFamily,
  176. padding: const EdgeInsets.symmetric(vertical: 14.0),
  177. onPressed: onPressed,
  178. fillColor: Theme.of(context).colorScheme.primary,
  179. fontColor: Theme.of(context).colorScheme.onPrimary,
  180. hoverColor: Theme.of(context).colorScheme.primaryContainer,
  181. );
  182. }
  183. }
  184. class _SkipLoginMoveWindow extends StatelessWidget
  185. implements PreferredSizeWidget {
  186. const _SkipLoginMoveWindow();
  187. @override
  188. Widget build(BuildContext context) {
  189. return const Row(
  190. children: [
  191. Expanded(
  192. child: MoveWindowDetector(),
  193. ),
  194. ],
  195. );
  196. }
  197. @override
  198. Size get preferredSize => const Size.fromHeight(55.0);
  199. }