Files
GitJournal/lib/widgets/app_drawer.dart
Vishesh Handa 0b161a9df4 Transition to Folders page with a fade
It's at the same hierarchy as 'Notes' and we shouldn't have a bottom to
top transition.
2019-12-06 12:11:39 +01:00

219 lines
6.4 KiB
Dart

import 'dart:io';
import 'package:flutter/material.dart';
import 'package:flutter_email_sender/flutter_email_sender.dart';
import 'package:launch_review/launch_review.dart';
import 'package:share/share.dart';
import 'package:url_launcher/url_launcher.dart';
import 'package:page_transition/page_transition.dart';
import 'package:gitjournal/analytics.dart';
import 'package:gitjournal/state_container.dart';
import 'package:gitjournal/utils.dart';
import 'package:gitjournal/screens/folder_listing.dart';
class AppDrawer extends StatelessWidget {
@override
Widget build(BuildContext context) {
Widget setupGitButton;
var appState = StateContainer.of(context).appState;
var textStyle = Theme.of(context).textTheme.body2;
if (!appState.remoteGitRepoConfigured) {
setupGitButton = ListTile(
leading: Icon(Icons.sync, color: textStyle.color),
title: Text('Setup Git Host', style: textStyle),
trailing: Icon(
Icons.info,
color: Colors.red,
),
onTap: () {
Navigator.pop(context);
Navigator.pushNamed(context, "/setupRemoteGit");
getAnalytics().logEvent(
name: "drawer_setupGitHost",
);
},
);
}
var divider = Row(children: <Widget>[
Expanded(
child: Divider(
color: Theme.of(context).primaryColorLight,
))
]);
return Drawer(
child: ListView(
// Important: Remove any padding from the ListView.
padding: EdgeInsets.zero,
children: <Widget>[
DrawerHeader(
decoration: BoxDecoration(
color: Theme.of(context).highlightColor,
),
child: Padding(
padding: const EdgeInsets.all(8.0),
child: DecoratedBox(
decoration: BoxDecoration(
image: DecorationImage(
image: const AssetImage('assets/icon/icon.png'),
),
),
),
),
),
if (setupGitButton != null) ...[setupGitButton, divider],
_buildDrawerTile(
context,
icon: Icons.note,
title: "Notes",
onTap: () {
var m = ModalRoute.of(context);
if (m.settings.name == "/") {
Navigator.pop(context);
} else {
Navigator.popUntil(
context, (route) => route.settings.name == '/');
}
},
),
_buildDrawerTile(
context,
icon: Icons.folder,
title: "Folders",
onTap: () {
var m = ModalRoute.of(context);
if (m.settings.name == "/folders") {
Navigator.pop(context);
} else {
Navigator.pop(context);
Navigator.push(
context,
PageTransition(
type: PageTransitionType.fade,
child: FolderListingScreen(),
),
);
}
},
),
divider,
_buildDrawerTile(
context,
icon: Icons.share,
title: 'Share App',
onTap: () {
Navigator.pop(context);
Share.share('Checkout GitJournal https://gitjournal.io/');
getAnalytics().logEvent(
name: "drawer_share",
);
},
),
_buildDrawerTile(
context,
icon: Icons.feedback,
title: 'Rate Us',
onTap: () {
LaunchReview.launch(
androidAppId: "io.gitjournal.gitjournal",
iOSAppId: "1466519634",
);
Navigator.pop(context);
getAnalytics().logEvent(
name: "drawer_rate",
);
},
),
_buildDrawerTile(
context,
icon: Icons.rate_review,
title: 'Feedback',
onTap: () async {
var versionText = await getVersionString();
var platform = Platform.operatingSystem;
var emailAddress = 'feedback@gitjournal.io';
var subject = 'GitJournal Feedback';
var body =
"Hey!\n\nHere are some ways to improve GitJournal - \n \n\nVersion: $versionText\nPlatform: $platform";
subject = Uri.encodeComponent(subject);
body = Uri.encodeComponent(body);
var url = 'mailto:$emailAddress?subject=$subject&body=$body';
launch(url);
Navigator.pop(context);
getAnalytics().logEvent(
name: "drawer_feedback",
);
},
),
_buildDrawerTile(
context,
icon: Icons.bug_report,
title: 'Bug Report',
onTap: () async {
var platform = Platform.operatingSystem;
var versionText = await getVersionString();
var appLogsFilePath = await dumpAppLogs();
final Email email = Email(
body:
"Hey!\n\nI found a bug in GitJournal - \n \n\nVersion: $versionText\nPlatform: $platform",
subject: 'GitJournal Bug',
recipients: ['bugs@gitjournal.io'],
attachmentPath: appLogsFilePath,
);
await FlutterEmailSender.send(email);
Navigator.pop(context);
getAnalytics().logEvent(
name: "drawer_bugreport",
);
},
),
_buildDrawerTile(
context,
icon: Icons.settings,
title: 'Settings',
onTap: () {
Navigator.pop(context);
Navigator.pushNamed(context, "/settings");
getAnalytics().logEvent(
name: "drawer_settings",
);
},
),
],
),
);
}
ListTile _buildDrawerTile(
BuildContext context, {
@required IconData icon,
@required String title,
@required Function onTap,
}) {
var textStyle = Theme.of(context).textTheme.body2;
return ListTile(
leading: Icon(icon, color: textStyle.color),
title: Text(title, style: textStyle),
onTap: onTap,
);
}
}