mirror of
https://github.com/GitJournal/GitJournal.git
synced 2025-07-15 07:56:11 +08:00

Clicking on Folders in AppBar when inside a Folder wouldn't take you back to the Folder Listing.
250 lines
7.7 KiB
Dart
250 lines
7.7 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:fetch_app_logs/fetch_app_logs.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;
|
|
var currentRoute = ModalRoute.of(context).settings.name;
|
|
|
|
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>[const Expanded(child: Divider())]);
|
|
|
|
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: const Padding(
|
|
padding: EdgeInsets.all(8.0),
|
|
child: DecoratedBox(
|
|
decoration: BoxDecoration(
|
|
image: DecorationImage(
|
|
image: 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 == '/');
|
|
}
|
|
},
|
|
selected: currentRoute == '/',
|
|
),
|
|
_buildDrawerTile(
|
|
context,
|
|
icon: Icons.folder,
|
|
title: "Folders",
|
|
onTap: () {
|
|
var m = ModalRoute.of(context);
|
|
if (m.settings.name == '/') {
|
|
Navigator.pop(context);
|
|
Navigator.push(
|
|
context,
|
|
PageTransition(
|
|
type: PageTransitionType.fade,
|
|
child: FolderListingScreen(),
|
|
settings: const RouteSettings(name: '/folders'),
|
|
),
|
|
);
|
|
} else if (m.settings.name == '/folders') {
|
|
Navigator.pop(context);
|
|
} else {
|
|
// Check if '/folders' is a parent
|
|
var wasParent = false;
|
|
Navigator.popUntil(
|
|
context,
|
|
(route) {
|
|
wasParent = route.settings.name == '/folders';
|
|
return wasParent;
|
|
},
|
|
);
|
|
if (!wasParent) {
|
|
Navigator.push(
|
|
context,
|
|
PageTransition(
|
|
type: PageTransitionType.fade,
|
|
child: FolderListingScreen(),
|
|
settings: const RouteSettings(name: '/folders'),
|
|
),
|
|
);
|
|
}
|
|
}
|
|
},
|
|
selected: currentRoute == null,
|
|
),
|
|
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 FetchAppLogs.dumpAppLogsToFile();
|
|
|
|
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",
|
|
);
|
|
},
|
|
),
|
|
],
|
|
),
|
|
);
|
|
}
|
|
|
|
Widget _buildDrawerTile(
|
|
BuildContext context, {
|
|
@required IconData icon,
|
|
@required String title,
|
|
@required Function onTap,
|
|
bool selected = false,
|
|
}) {
|
|
selected = false; // Disable this as it looks very ugly in dark mode
|
|
|
|
var theme = Theme.of(context);
|
|
var listTileTheme = ListTileTheme.of(context);
|
|
var textStyle = theme.textTheme.body2.copyWith(
|
|
color: selected ? theme.accentColor : listTileTheme.textColor,
|
|
);
|
|
|
|
var tile = ListTile(
|
|
leading: Icon(icon, color: textStyle.color),
|
|
title: Text(title, style: textStyle),
|
|
onTap: onTap,
|
|
selected: selected,
|
|
);
|
|
return Container(
|
|
child: tile,
|
|
color: selected ? theme.selectedRowColor : theme.scaffoldBackgroundColor,
|
|
);
|
|
}
|
|
}
|