ente/lib/ui/landing_page_widget.dart
2021-10-30 11:13:56 +05:30

304 lines
8.7 KiB
Dart

import 'package:dots_indicator/dots_indicator.dart';
import 'package:flutter/material.dart';
import 'package:flutter/widgets.dart';
import 'package:flutter_gen/gen_l10n/app_localizations.dart';
import 'package:photos/core/configuration.dart';
import 'package:photos/ui/email_entry_page.dart';
import 'package:photos/ui/login_page.dart';
import 'package:photos/ui/password_entry_page.dart';
import 'package:photos/ui/password_reentry_page.dart';
import 'package:photos/ui/payment/subscription.dart';
class LandingPageWidget extends StatefulWidget {
const LandingPageWidget({Key key}) : super(key: key);
@override
_LandingPageWidgetState createState() => _LandingPageWidgetState();
}
class _LandingPageWidgetState extends State<LandingPageWidget> {
double _featureIndex = 0;
@override
Widget build(BuildContext context) {
return Scaffold(body: _getBody(), resizeToAvoidBottomInset: false);
}
Widget _getBody() {
return Center(
child: SingleChildScrollView(
child: Column(
children: [
Padding(padding: const EdgeInsets.all(12)),
Text.rich(
TextSpan(
children: const <TextSpan>[
TextSpan(
text: "with ",
style: TextStyle(
fontSize: 16,
),
),
TextSpan(
text: "ente",
style: TextStyle(
fontWeight: FontWeight.bold,
fontFamily: 'Montserrat',
fontSize: 16,
),
),
],
),
textAlign: TextAlign.center,
),
Padding(
padding: EdgeInsets.all(2),
),
Text.rich(
TextSpan(
children: const <TextSpan>[
TextSpan(
text: "your ",
style: TextStyle(
fontSize: 16,
),
),
TextSpan(
text: "memories",
style: TextStyle(
fontWeight: FontWeight.bold,
fontSize: 16,
),
),
TextSpan(
text: " are",
style: TextStyle(
fontSize: 16,
),
),
],
),
textAlign: TextAlign.center,
),
Padding(
padding: EdgeInsets.all(24),
),
_getFeatureSlider(),
DotsIndicator(
dotsCount: 3,
position: _featureIndex,
decorator: DotsDecorator(
color: Colors.white24, // Inactive color
activeColor: Theme.of(context).buttonColor,
),
),
Padding(
padding: EdgeInsets.all(28),
),
_getSignUpButton(context),
Padding(
padding: EdgeInsets.all(4),
),
GestureDetector(
behavior: HitTestBehavior.translucent,
child: Container(
width: double.infinity,
padding: EdgeInsets.all(28),
child: Center(
child: Hero(
tag: "log_in",
child: Material(
type: MaterialType.transparency,
child: Text(
AppLocalizations.of(context).log_in,
style: TextStyle(
fontWeight: FontWeight.bold,
fontSize: 16,
letterSpacing: 0.6,
color: Colors.white.withOpacity(0.95),
),
),
),
),
),
),
onTap: _navigateToSignInPage,
),
Padding(
padding: EdgeInsets.all(20),
),
],
),
),
);
}
Widget _getSignUpButton(BuildContext context) {
return SizedBox(
width: 200,
height: 64,
child: OutlinedButton(
style: OutlinedButton.styleFrom(
shape: RoundedRectangleBorder(
borderRadius: BorderRadius.circular(10),
),
padding: EdgeInsets.fromLTRB(50, 16, 50, 16),
side: BorderSide(
width: 2,
color: Theme.of(context).buttonColor,
),
),
child: Hero(
tag: "sign_up",
child: Material(
type: MaterialType.transparency,
child: Text(
AppLocalizations.of(context).sign_up,
style: TextStyle(
fontWeight: FontWeight.bold,
fontSize: 18,
letterSpacing: 0.6,
),
),
),
),
onPressed: _navigateToSignUpPage,
),
);
}
Widget _getFeatureSlider() {
return ConstrainedBox(
constraints: BoxConstraints(maxHeight: 320),
child: PageView(
children: const [
FeatureItemWidget(
"assets/protected.png",
"protected",
"end-to-end encrypted with your password,",
"visible only to you"),
FeatureItemWidget("assets/synced.png", "synced",
"available across all your devices,", "web, android and ios"),
FeatureItemWidget(
"assets/preserved.png",
"preserved",
"reliably replicated to a fallout shelter,",
"designed to outlive"),
],
onPageChanged: (index) {
setState(() {
_featureIndex = double.parse(index.toString());
});
},
),
);
}
void _navigateToSignUpPage() {
Widget page;
if (Configuration.instance.getEncryptedToken() == null) {
page = EmailEntryPage();
} else {
// No key
if (Configuration.instance.getKeyAttributes() == null) {
// Never had a key
page = PasswordEntryPage();
} else if (Configuration.instance.getKey() == null) {
// Yet to decrypt the key
page = PasswordReentryPage();
} else {
// All is well, user just has not subscribed
page = getSubscriptionPage(isOnBoarding: true);
}
}
Navigator.of(context).push(
MaterialPageRoute(
builder: (BuildContext context) {
return page;
},
),
);
}
void _navigateToSignInPage() {
Widget page;
if (Configuration.instance.getEncryptedToken() == null) {
page = LoginPage();
} else {
// No key
if (Configuration.instance.getKeyAttributes() == null) {
// Never had a key
page = PasswordEntryPage();
} else if (Configuration.instance.getKey() == null) {
// Yet to decrypt the key
page = PasswordReentryPage();
} else {
// All is well, user just has not subscribed
page = getSubscriptionPage(isOnBoarding: true);
}
}
Navigator.of(context).push(
MaterialPageRoute(
builder: (BuildContext context) {
return page;
},
),
);
}
}
class FeatureItemWidget extends StatelessWidget {
final String assetPath, featureTitle, firstLine, secondLine;
const FeatureItemWidget(
this.assetPath,
this.featureTitle,
this.firstLine,
this.secondLine, {
Key key,
}) : super(key: key);
@override
Widget build(BuildContext context) {
return Column(
crossAxisAlignment: CrossAxisAlignment.stretch,
children: [
Image.asset(
assetPath,
height: 160,
),
Padding(padding: EdgeInsets.all(16)),
Column(
crossAxisAlignment: CrossAxisAlignment.center,
mainAxisAlignment: MainAxisAlignment.start,
children: [
Text(
featureTitle,
style: TextStyle(
fontSize: 18,
fontWeight: FontWeight.bold,
color: Theme.of(context).buttonColor,
),
),
Padding(padding: EdgeInsets.all(12)),
Text(
firstLine,
textAlign: TextAlign.center,
style: TextStyle(
color: Colors.white.withOpacity(0.9),
),
),
Padding(padding: EdgeInsets.all(2)),
Text(
secondLine,
textAlign: TextAlign.center,
style: TextStyle(
color: Colors.white.withOpacity(0.9),
),
),
],
),
],
);
}
}