2019-07-25 09:26:13 -07:00
|
|
|
import 'package:permission_handler/permission_handler.dart';
|
|
|
|
import 'package:path_provider/path_provider.dart';
|
|
|
|
import 'package:file_picker/file_picker.dart';
|
2019-04-24 00:27:23 -07:00
|
|
|
import 'package:flutter/material.dart';
|
|
|
|
import 'global_helper_functions.dart';
|
2019-07-25 09:26:13 -07:00
|
|
|
import 'database_helper.dart';
|
|
|
|
import 'dart:io';
|
2019-04-24 00:27:23 -07:00
|
|
|
|
|
|
|
class Settings extends StatefulWidget {
|
|
|
|
@override
|
2019-06-27 17:29:40 -07:00
|
|
|
_SettingsState createState() => _SettingsState();
|
2019-04-24 00:27:23 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
class _SettingsState extends State<Settings> {
|
2019-07-25 09:26:13 -07:00
|
|
|
// String absoluteDBExportFileName = '';
|
|
|
|
String _dbExportFileNameString = '';
|
2019-04-24 00:27:23 -07:00
|
|
|
String elevationServer = "none";
|
2019-06-27 17:29:40 -07:00
|
|
|
String openWeatherMapKey = "none??";
|
2019-04-24 00:27:23 -07:00
|
|
|
String shortOWMAK = "none";
|
2019-07-25 09:26:13 -07:00
|
|
|
final _dbExportFileNameController = TextEditingController();
|
2019-04-24 00:27:23 -07:00
|
|
|
final _elevationServerController = TextEditingController();
|
|
|
|
final _oWMKController = TextEditingController();
|
2019-06-27 17:29:40 -07:00
|
|
|
bool _useElevation = false;
|
|
|
|
bool _useWeather = false;
|
|
|
|
double textHeight = 1.5;
|
2019-04-24 00:27:23 -07:00
|
|
|
|
|
|
|
@override
|
|
|
|
void initState() {
|
|
|
|
super.initState();
|
|
|
|
updateState();
|
|
|
|
}
|
|
|
|
|
|
|
|
@override
|
|
|
|
Widget build(BuildContext context) {
|
2019-07-27 15:34:01 -07:00
|
|
|
Future<void> _showDBImportDialog() async {
|
2019-07-25 09:26:13 -07:00
|
|
|
Map<PermissionGroup, PermissionStatus> _storagePermissions;
|
2019-07-27 15:34:01 -07:00
|
|
|
PermissionStatus _storagePermission = await PermissionHandler()
|
|
|
|
.checkPermissionStatus(PermissionGroup.storage);
|
2019-07-25 09:26:13 -07:00
|
|
|
if (_storagePermission == PermissionStatus.denied) {
|
2019-07-27 15:34:01 -07:00
|
|
|
_storagePermissions = await PermissionHandler()
|
|
|
|
.requestPermissions([PermissionGroup.storage]);
|
2019-07-25 09:26:13 -07:00
|
|
|
}
|
2019-07-27 15:34:01 -07:00
|
|
|
if ((_storagePermission == PermissionStatus.granted) ||
|
|
|
|
(_storagePermissions.toString() ==
|
|
|
|
PermissionStatus.granted.toString())) {
|
2019-07-25 09:26:13 -07:00
|
|
|
showDialog(
|
2019-07-27 15:34:01 -07:00
|
|
|
context: context,
|
|
|
|
builder: (BuildContext context) {
|
|
|
|
return AlertDialog(
|
|
|
|
backgroundColor: ivory,
|
|
|
|
shape: RoundedRectangleBorder(
|
|
|
|
borderRadius: BorderRadius.all(Radius.circular(6.0)),
|
2019-07-25 09:26:13 -07:00
|
|
|
),
|
2019-07-27 15:34:01 -07:00
|
|
|
title: Text(
|
|
|
|
'You can import a\njson backup of\nyour database',
|
|
|
|
textAlign: TextAlign.center,
|
|
|
|
style: TextStyle(
|
|
|
|
color: candyApple,
|
|
|
|
),
|
|
|
|
),
|
|
|
|
content: Column(
|
|
|
|
mainAxisSize: MainAxisSize.min,
|
|
|
|
children: <Widget>[
|
|
|
|
Container(
|
|
|
|
margin: EdgeInsets.only(
|
|
|
|
top: 40,
|
|
|
|
bottom: 10,
|
2019-07-25 09:26:13 -07:00
|
|
|
),
|
2019-07-27 15:34:01 -07:00
|
|
|
child: ButtonTheme(
|
|
|
|
height: 55,
|
|
|
|
padding: EdgeInsets.only(
|
|
|
|
top: 5, right: 12, bottom: 12, left: 10),
|
|
|
|
child: RaisedButton(
|
|
|
|
shape: RoundedRectangleBorder(
|
|
|
|
borderRadius:
|
|
|
|
BorderRadius.all(Radius.circular(6.0)),
|
|
|
|
),
|
|
|
|
color: peacockBlue,
|
|
|
|
child: Text(
|
|
|
|
'Select File',
|
|
|
|
style: TextStyle(
|
|
|
|
height: textHeight,
|
|
|
|
color: Colors.white,
|
|
|
|
fontSize: 24,
|
|
|
|
),
|
|
|
|
),
|
|
|
|
onPressed: () async {
|
|
|
|
String _filePath;
|
|
|
|
_filePath = await FilePicker.getFilePath(
|
|
|
|
type: FileType.ANY);
|
|
|
|
Navigator.of(context).pop();
|
|
|
|
try {
|
|
|
|
String _importString =
|
|
|
|
await File(_filePath).readAsString();
|
|
|
|
bool _imported =
|
|
|
|
await importDataBase(_importString);
|
|
|
|
if (_imported) {
|
|
|
|
showDialog(
|
|
|
|
context: context,
|
|
|
|
builder: (BuildContext context) {
|
|
|
|
return AlertDialog(
|
|
|
|
backgroundColor: ivory,
|
|
|
|
shape: RoundedRectangleBorder(
|
|
|
|
borderRadius: BorderRadius.all(
|
|
|
|
Radius.circular(6.0)),
|
2019-07-25 09:26:13 -07:00
|
|
|
),
|
2019-07-27 15:34:01 -07:00
|
|
|
title: Text(
|
|
|
|
'Importing From\n\'$_filePath\'\n Succeeded!',
|
|
|
|
textAlign: TextAlign.center,
|
|
|
|
style: TextStyle(
|
|
|
|
color: candyApple,
|
2019-07-25 09:26:13 -07:00
|
|
|
),
|
2019-07-27 15:34:01 -07:00
|
|
|
),
|
|
|
|
content: Column(
|
|
|
|
mainAxisSize: MainAxisSize.min,
|
|
|
|
children: <Widget>[
|
|
|
|
Container(
|
|
|
|
margin: EdgeInsets.only(
|
|
|
|
top: 40,
|
|
|
|
bottom: 10,
|
|
|
|
),
|
|
|
|
child: ButtonTheme(
|
|
|
|
height: 55,
|
|
|
|
padding: EdgeInsets.only(
|
|
|
|
top: 5,
|
|
|
|
right: 12,
|
|
|
|
bottom: 12,
|
|
|
|
left: 10),
|
|
|
|
child: RaisedButton(
|
|
|
|
shape:
|
|
|
|
RoundedRectangleBorder(
|
|
|
|
borderRadius:
|
|
|
|
BorderRadius.all(
|
|
|
|
Radius.circular(
|
|
|
|
6.0)),
|
|
|
|
),
|
|
|
|
color: peacockBlue,
|
|
|
|
child: Text(
|
|
|
|
'OK',
|
|
|
|
style: TextStyle(
|
|
|
|
height: textHeight,
|
|
|
|
color: Colors.white,
|
|
|
|
fontSize: 24,
|
|
|
|
),
|
|
|
|
),
|
|
|
|
onPressed: () async {
|
|
|
|
Navigator.of(context)
|
|
|
|
.pop();
|
|
|
|
}),
|
2019-07-25 09:26:13 -07:00
|
|
|
),
|
|
|
|
),
|
2019-07-27 15:34:01 -07:00
|
|
|
],
|
2019-07-25 09:26:13 -07:00
|
|
|
),
|
2019-07-27 15:34:01 -07:00
|
|
|
);
|
|
|
|
});
|
2019-07-25 09:26:13 -07:00
|
|
|
}
|
2019-07-27 15:34:01 -07:00
|
|
|
} catch (e) {
|
|
|
|
print(e);
|
|
|
|
showDialog(
|
|
|
|
context: context,
|
|
|
|
builder: (BuildContext context) {
|
|
|
|
return AlertDialog(
|
|
|
|
backgroundColor: ivory,
|
|
|
|
shape: RoundedRectangleBorder(
|
|
|
|
borderRadius: BorderRadius.all(
|
|
|
|
Radius.circular(6.0)),
|
2019-07-25 09:26:13 -07:00
|
|
|
),
|
2019-07-27 15:34:01 -07:00
|
|
|
title: Text(
|
|
|
|
'Oops, something went wrong',
|
|
|
|
textAlign: TextAlign.center,
|
|
|
|
style: TextStyle(
|
|
|
|
color: candyApple,
|
2019-07-25 09:26:13 -07:00
|
|
|
),
|
2019-07-27 15:34:01 -07:00
|
|
|
),
|
|
|
|
content: Column(
|
|
|
|
mainAxisSize: MainAxisSize.min,
|
|
|
|
children: <Widget>[
|
|
|
|
Container(
|
|
|
|
margin: EdgeInsets.only(
|
|
|
|
top: 40,
|
|
|
|
bottom: 10,
|
|
|
|
),
|
|
|
|
child: ButtonTheme(
|
|
|
|
height: 55,
|
|
|
|
padding: EdgeInsets.only(
|
|
|
|
top: 5,
|
|
|
|
right: 12,
|
|
|
|
bottom: 12,
|
|
|
|
left: 10),
|
|
|
|
child: RaisedButton(
|
|
|
|
shape:
|
|
|
|
RoundedRectangleBorder(
|
|
|
|
borderRadius:
|
|
|
|
BorderRadius.all(
|
|
|
|
Radius.circular(
|
|
|
|
6.0)),
|
|
|
|
),
|
|
|
|
color: peacockBlue,
|
|
|
|
child: Text(
|
|
|
|
'OK',
|
|
|
|
style: TextStyle(
|
|
|
|
height: textHeight,
|
|
|
|
color: Colors.white,
|
|
|
|
fontSize: 24,
|
|
|
|
),
|
|
|
|
),
|
|
|
|
onPressed: () async {
|
|
|
|
Navigator.of(context)
|
|
|
|
.pop();
|
|
|
|
}),
|
2019-07-25 09:26:13 -07:00
|
|
|
),
|
|
|
|
),
|
2019-07-27 15:34:01 -07:00
|
|
|
],
|
2019-07-25 09:26:13 -07:00
|
|
|
),
|
2019-07-27 15:34:01 -07:00
|
|
|
);
|
|
|
|
});
|
2019-07-25 09:26:13 -07:00
|
|
|
}
|
2019-07-27 15:34:01 -07:00
|
|
|
}),
|
2019-07-25 09:26:13 -07:00
|
|
|
),
|
|
|
|
),
|
2019-07-27 15:34:01 -07:00
|
|
|
],
|
|
|
|
),
|
|
|
|
);
|
|
|
|
});
|
2019-07-25 09:26:13 -07:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-07-27 15:34:01 -07:00
|
|
|
Future<void> _showDBExportDialog() async {
|
2019-07-25 09:26:13 -07:00
|
|
|
Map<PermissionGroup, PermissionStatus> _storagePermissions;
|
2019-07-27 15:34:01 -07:00
|
|
|
PermissionStatus _storagePermission = await PermissionHandler()
|
|
|
|
.checkPermissionStatus(PermissionGroup.storage);
|
2019-07-25 09:26:13 -07:00
|
|
|
if (_storagePermission == PermissionStatus.denied) {
|
2019-07-27 15:34:01 -07:00
|
|
|
_storagePermissions = await PermissionHandler()
|
|
|
|
.requestPermissions([PermissionGroup.storage]);
|
2019-07-25 09:26:13 -07:00
|
|
|
}
|
2019-07-27 15:34:01 -07:00
|
|
|
if ((_storagePermission == PermissionStatus.granted) ||
|
|
|
|
(_storagePermissions.toString() ==
|
|
|
|
PermissionStatus.granted.toString())) {
|
2019-07-25 09:26:13 -07:00
|
|
|
Directory sdcard = await getExternalStorageDirectory();
|
|
|
|
showDialog(
|
2019-07-27 15:34:01 -07:00
|
|
|
context: context,
|
|
|
|
builder: (BuildContext context) {
|
|
|
|
return AlertDialog(
|
|
|
|
backgroundColor: ivory,
|
|
|
|
shape: RoundedRectangleBorder(
|
|
|
|
borderRadius: BorderRadius.all(Radius.circular(6.0)),
|
2019-07-25 09:26:13 -07:00
|
|
|
),
|
2019-07-27 15:34:01 -07:00
|
|
|
title: Text(
|
|
|
|
'Export File Name?',
|
|
|
|
textAlign: TextAlign.center,
|
|
|
|
style: TextStyle(
|
|
|
|
color: candyApple,
|
2019-07-25 09:26:13 -07:00
|
|
|
),
|
2019-07-27 15:34:01 -07:00
|
|
|
),
|
|
|
|
content: Column(
|
|
|
|
mainAxisSize: MainAxisSize.min,
|
|
|
|
children: <Widget>[
|
|
|
|
Text(
|
|
|
|
'DataBase will be\nexported to json file.',
|
|
|
|
style: TextStyle(
|
|
|
|
fontSize: 16,
|
|
|
|
),
|
2019-07-25 09:26:13 -07:00
|
|
|
),
|
2019-07-27 15:34:01 -07:00
|
|
|
TextField(
|
|
|
|
controller: _dbExportFileNameController,
|
|
|
|
keyboardType: TextInputType.multiline,
|
|
|
|
maxLines: null,
|
|
|
|
decoration: InputDecoration(
|
|
|
|
hintText: this._dbExportFileNameString,
|
|
|
|
),
|
|
|
|
onChanged: (text) {
|
|
|
|
this._dbExportFileNameString =
|
|
|
|
(text.length > 0) ? text : "libre_gps_parser.json";
|
|
|
|
},
|
2019-07-25 09:26:13 -07:00
|
|
|
),
|
2019-07-27 15:34:01 -07:00
|
|
|
Container(
|
|
|
|
margin: EdgeInsets.only(
|
|
|
|
top: 40,
|
|
|
|
bottom: 10,
|
2019-07-25 09:26:13 -07:00
|
|
|
),
|
2019-07-27 15:34:01 -07:00
|
|
|
child: ButtonTheme(
|
|
|
|
height: 55,
|
|
|
|
padding: EdgeInsets.only(
|
|
|
|
top: 5, right: 12, bottom: 12, left: 10),
|
|
|
|
child: RaisedButton(
|
|
|
|
shape: RoundedRectangleBorder(
|
|
|
|
borderRadius:
|
|
|
|
BorderRadius.all(Radius.circular(6.0)),
|
|
|
|
),
|
|
|
|
color: peacockBlue,
|
|
|
|
child: Text(
|
|
|
|
'Export',
|
|
|
|
style: TextStyle(
|
|
|
|
height: textHeight,
|
|
|
|
color: Colors.white,
|
|
|
|
fontSize: 24,
|
|
|
|
),
|
|
|
|
),
|
|
|
|
onPressed: () async {
|
|
|
|
_updatedbExportFileName();
|
|
|
|
final dbHelper = DatabaseHelper.instance;
|
|
|
|
String _dbExportString =
|
|
|
|
await dbHelper.queryDBExport();
|
|
|
|
String _absoluteDBExportFileName =
|
|
|
|
'${sdcard.path}/${this._dbExportFileNameString}';
|
|
|
|
File _file = File(_absoluteDBExportFileName);
|
|
|
|
File _result =
|
|
|
|
await _file.writeAsString(_dbExportString);
|
|
|
|
Navigator.of(context).pop();
|
|
|
|
if (_result == null) {
|
|
|
|
showDialog(
|
|
|
|
context: context,
|
|
|
|
builder: (BuildContext context) {
|
|
|
|
return AlertDialog(
|
|
|
|
backgroundColor: ivory,
|
|
|
|
shape: RoundedRectangleBorder(
|
|
|
|
borderRadius: BorderRadius.all(
|
|
|
|
Radius.circular(6.0)),
|
2019-07-25 09:26:13 -07:00
|
|
|
),
|
2019-07-27 15:34:01 -07:00
|
|
|
title: Text(
|
|
|
|
'Writing To\n\'$_absoluteDBExportFileName\'\n(sdcard) Failed!',
|
|
|
|
textAlign: TextAlign.center,
|
|
|
|
style: TextStyle(
|
|
|
|
color: candyApple,
|
2019-07-25 09:26:13 -07:00
|
|
|
),
|
2019-07-27 15:34:01 -07:00
|
|
|
),
|
|
|
|
content: Column(
|
|
|
|
mainAxisSize: MainAxisSize.min,
|
|
|
|
children: <Widget>[
|
|
|
|
Container(
|
|
|
|
margin: EdgeInsets.only(
|
|
|
|
top: 40,
|
|
|
|
bottom: 10,
|
|
|
|
),
|
|
|
|
child: ButtonTheme(
|
|
|
|
height: 55,
|
|
|
|
padding: EdgeInsets.only(
|
|
|
|
top: 5,
|
|
|
|
right: 12,
|
|
|
|
bottom: 12,
|
|
|
|
left: 10),
|
|
|
|
child: RaisedButton(
|
|
|
|
shape:
|
|
|
|
RoundedRectangleBorder(
|
|
|
|
borderRadius:
|
|
|
|
BorderRadius.all(
|
|
|
|
Radius.circular(
|
|
|
|
6.0)),
|
|
|
|
),
|
|
|
|
color: peacockBlue,
|
|
|
|
child: Text(
|
|
|
|
'OK',
|
|
|
|
style: TextStyle(
|
|
|
|
height: textHeight,
|
|
|
|
color: Colors.white,
|
|
|
|
fontSize: 24,
|
|
|
|
),
|
|
|
|
),
|
|
|
|
onPressed: () async {
|
|
|
|
Navigator.of(context)
|
|
|
|
.pop();
|
|
|
|
}),
|
2019-07-25 09:26:13 -07:00
|
|
|
),
|
|
|
|
),
|
2019-07-27 15:34:01 -07:00
|
|
|
],
|
2019-07-25 09:26:13 -07:00
|
|
|
),
|
2019-07-27 15:34:01 -07:00
|
|
|
);
|
|
|
|
});
|
|
|
|
} else {
|
|
|
|
showDialog(
|
|
|
|
context: context,
|
|
|
|
builder: (BuildContext context) {
|
|
|
|
return AlertDialog(
|
|
|
|
backgroundColor: ivory,
|
|
|
|
shape: RoundedRectangleBorder(
|
|
|
|
borderRadius: BorderRadius.all(
|
|
|
|
Radius.circular(6.0)),
|
2019-07-25 09:26:13 -07:00
|
|
|
),
|
2019-07-27 15:34:01 -07:00
|
|
|
title: Text(
|
|
|
|
'Writing To\n\'$_absoluteDBExportFileName\'\n(sdcard) Succeeded!',
|
|
|
|
textAlign: TextAlign.center,
|
|
|
|
style: TextStyle(
|
|
|
|
color: candyApple,
|
2019-07-25 09:26:13 -07:00
|
|
|
),
|
2019-07-27 15:34:01 -07:00
|
|
|
),
|
|
|
|
content: Column(
|
|
|
|
mainAxisSize: MainAxisSize.min,
|
|
|
|
children: <Widget>[
|
|
|
|
Container(
|
|
|
|
margin: EdgeInsets.only(
|
|
|
|
top: 40,
|
|
|
|
bottom: 10,
|
|
|
|
),
|
|
|
|
child: ButtonTheme(
|
|
|
|
height: 55,
|
|
|
|
padding: EdgeInsets.only(
|
|
|
|
top: 5,
|
|
|
|
right: 12,
|
|
|
|
bottom: 12,
|
|
|
|
left: 10),
|
|
|
|
child: RaisedButton(
|
|
|
|
shape:
|
|
|
|
RoundedRectangleBorder(
|
|
|
|
borderRadius:
|
|
|
|
BorderRadius.all(
|
|
|
|
Radius.circular(
|
|
|
|
6.0)),
|
|
|
|
),
|
|
|
|
color: peacockBlue,
|
|
|
|
child: Text(
|
|
|
|
'OK',
|
|
|
|
style: TextStyle(
|
|
|
|
height: textHeight,
|
|
|
|
color: Colors.white,
|
|
|
|
fontSize: 24,
|
|
|
|
),
|
|
|
|
),
|
|
|
|
onPressed: () async {
|
|
|
|
Navigator.of(context)
|
|
|
|
.pop();
|
|
|
|
}),
|
2019-07-25 09:26:13 -07:00
|
|
|
),
|
|
|
|
),
|
2019-07-27 15:34:01 -07:00
|
|
|
],
|
2019-07-25 09:26:13 -07:00
|
|
|
),
|
2019-07-27 15:34:01 -07:00
|
|
|
);
|
|
|
|
});
|
2019-07-25 09:26:13 -07:00
|
|
|
}
|
2019-07-27 15:34:01 -07:00
|
|
|
}),
|
2019-07-25 09:26:13 -07:00
|
|
|
),
|
|
|
|
),
|
2019-07-27 15:34:01 -07:00
|
|
|
],
|
|
|
|
),
|
|
|
|
);
|
|
|
|
});
|
2019-07-25 09:26:13 -07:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-06-27 17:29:40 -07:00
|
|
|
return WillPopScope(
|
|
|
|
onWillPop: _popBack,
|
|
|
|
child: Scaffold(
|
|
|
|
backgroundColor: peacockBlue,
|
|
|
|
appBar: AppBar(
|
|
|
|
title: const Text('Settings'),
|
|
|
|
),
|
|
|
|
body: ListView(
|
|
|
|
children: <Widget>[
|
|
|
|
Container(
|
|
|
|
padding: myBoxPadding,
|
|
|
|
decoration: myBoxDecoration(ivory),
|
|
|
|
child: Row(
|
|
|
|
children: [
|
|
|
|
Expanded(
|
|
|
|
child: Text(
|
|
|
|
'Enable Elevation Api Server?',
|
|
|
|
style: TextStyle(
|
|
|
|
height: textHeight,
|
|
|
|
fontSize: 20,
|
|
|
|
),
|
2019-04-24 00:27:23 -07:00
|
|
|
),
|
2019-06-27 17:29:40 -07:00
|
|
|
),
|
|
|
|
Container(
|
|
|
|
padding: EdgeInsets.all(15.0),
|
|
|
|
child: Transform.scale(
|
|
|
|
scale: 2,
|
|
|
|
child: Switch(
|
|
|
|
value: this._useElevation,
|
|
|
|
onChanged: (value) {
|
2019-07-27 15:34:01 -07:00
|
|
|
setPreferenceUseElevation(value)
|
|
|
|
.then((bool committed) {
|
2019-06-27 17:29:40 -07:00
|
|
|
setState(() {
|
|
|
|
this._useElevation = value;
|
|
|
|
});
|
|
|
|
});
|
|
|
|
},
|
|
|
|
activeTrackColor: peacockBlue,
|
|
|
|
activeColor: navy,
|
|
|
|
inactiveThumbColor: candyApple,
|
|
|
|
),
|
2019-04-24 00:27:23 -07:00
|
|
|
),
|
2019-06-27 17:29:40 -07:00
|
|
|
),
|
|
|
|
],
|
|
|
|
),
|
|
|
|
),
|
2019-07-27 15:34:01 -07:00
|
|
|
((this._useElevation)
|
|
|
|
? Container(
|
|
|
|
padding: myBoxPadding,
|
|
|
|
decoration: myBoxDecoration(ivory),
|
|
|
|
child: Column(
|
|
|
|
children: [
|
|
|
|
Text(
|
|
|
|
'Open-Elevation Api Server to Use',
|
|
|
|
),
|
|
|
|
Text(
|
|
|
|
'Current Value: ${this.elevationServer}',
|
|
|
|
),
|
|
|
|
TextField(
|
|
|
|
controller: _elevationServerController,
|
|
|
|
decoration: InputDecoration(
|
|
|
|
hintText: this.elevationServer,
|
|
|
|
),
|
|
|
|
),
|
|
|
|
Container(
|
|
|
|
margin: EdgeInsets.only(
|
|
|
|
top: 20.0,
|
|
|
|
bottom: 5.0,
|
|
|
|
),
|
|
|
|
child: RaisedButton.icon(
|
|
|
|
label: Text(
|
|
|
|
"Update Elevation Server",
|
|
|
|
),
|
|
|
|
icon: Icon(
|
|
|
|
Icons.refresh,
|
|
|
|
size: 50.0,
|
|
|
|
),
|
|
|
|
color: candyApple,
|
|
|
|
onPressed: () {
|
|
|
|
_updateElevationServer();
|
|
|
|
},
|
|
|
|
),
|
|
|
|
),
|
|
|
|
],
|
2019-06-27 17:29:40 -07:00
|
|
|
),
|
2019-07-27 15:34:01 -07:00
|
|
|
)
|
|
|
|
: Container()),
|
2019-06-27 17:29:40 -07:00
|
|
|
Container(
|
|
|
|
padding: myBoxPadding,
|
|
|
|
decoration: myBoxDecoration(ivory),
|
|
|
|
child: Row(
|
|
|
|
children: [
|
|
|
|
Expanded(
|
|
|
|
child: Text(
|
|
|
|
'Use OpenWeatherMap Weather?',
|
|
|
|
style: TextStyle(
|
|
|
|
height: textHeight,
|
|
|
|
fontSize: 20,
|
|
|
|
),
|
2019-04-24 00:27:23 -07:00
|
|
|
),
|
2019-06-27 17:29:40 -07:00
|
|
|
),
|
|
|
|
Container(
|
|
|
|
padding: EdgeInsets.all(15.0),
|
|
|
|
child: Transform.scale(
|
|
|
|
scale: 2,
|
|
|
|
child: Switch(
|
|
|
|
value: this._useWeather,
|
|
|
|
onChanged: (value) {
|
|
|
|
setPreferenceUseWeather(value).then((bool committed) {
|
|
|
|
setState(() {
|
|
|
|
this._useWeather = value;
|
|
|
|
});
|
|
|
|
});
|
|
|
|
},
|
|
|
|
activeTrackColor: peacockBlue,
|
|
|
|
activeColor: navy,
|
|
|
|
inactiveThumbColor: candyApple,
|
|
|
|
),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
],
|
|
|
|
),
|
|
|
|
),
|
2019-07-27 15:34:01 -07:00
|
|
|
((this._useWeather)
|
|
|
|
? Container(
|
|
|
|
padding: myBoxPadding,
|
|
|
|
decoration: myBoxDecoration(ivory),
|
|
|
|
child: Column(
|
|
|
|
children: [
|
|
|
|
Text(
|
|
|
|
'Open Weather Map Api Key to Use',
|
|
|
|
),
|
|
|
|
Text(
|
|
|
|
'Current Value: ${this.shortOWMAK}...',
|
|
|
|
),
|
|
|
|
TextField(
|
|
|
|
controller: _oWMKController,
|
|
|
|
decoration: InputDecoration(
|
|
|
|
hintText: '${this.shortOWMAK}...',
|
|
|
|
),
|
|
|
|
),
|
|
|
|
Container(
|
|
|
|
margin: EdgeInsets.only(
|
|
|
|
top: 20.0,
|
|
|
|
bottom: 5.0,
|
|
|
|
),
|
|
|
|
child: RaisedButton.icon(
|
|
|
|
label: Text(
|
|
|
|
"Update ... Api Key",
|
|
|
|
),
|
|
|
|
icon: Icon(
|
|
|
|
Icons.refresh,
|
|
|
|
size: 50.0,
|
|
|
|
),
|
|
|
|
color: candyApple,
|
|
|
|
onPressed: () {
|
|
|
|
_updateOpenWeatherMapApiKey();
|
|
|
|
},
|
|
|
|
),
|
|
|
|
),
|
|
|
|
],
|
|
|
|
),
|
|
|
|
)
|
|
|
|
: Container()),
|
|
|
|
Container(
|
2019-06-27 17:29:40 -07:00
|
|
|
padding: myBoxPadding,
|
|
|
|
decoration: myBoxDecoration(ivory),
|
2019-07-27 15:34:01 -07:00
|
|
|
child: Row(
|
2019-06-27 17:29:40 -07:00
|
|
|
children: [
|
2019-07-27 15:34:01 -07:00
|
|
|
Expanded(
|
|
|
|
flex: 2,
|
|
|
|
child: IconButton(
|
|
|
|
alignment: Alignment.center,
|
|
|
|
icon: Icon(
|
|
|
|
Icons.arrow_back,
|
|
|
|
color: candyApple,
|
|
|
|
),
|
|
|
|
iconSize: 60.0,
|
|
|
|
onPressed: () {
|
|
|
|
_showDBExportDialog();
|
|
|
|
},
|
2019-04-24 00:27:23 -07:00
|
|
|
),
|
2019-06-27 17:29:40 -07:00
|
|
|
),
|
2019-07-27 15:34:01 -07:00
|
|
|
Expanded(
|
|
|
|
flex: 6,
|
|
|
|
child: Text(
|
|
|
|
'Export DataBase',
|
|
|
|
textAlign: TextAlign.center,
|
|
|
|
style: TextStyle(
|
|
|
|
height: textHeight,
|
|
|
|
fontSize: 20,
|
2019-04-24 00:27:23 -07:00
|
|
|
),
|
2019-07-27 15:34:01 -07:00
|
|
|
),
|
|
|
|
),
|
|
|
|
Expanded(
|
|
|
|
flex: 2,
|
|
|
|
child: IconButton(
|
|
|
|
alignment: Alignment.center,
|
2019-06-27 17:29:40 -07:00
|
|
|
icon: Icon(
|
2019-07-27 15:34:01 -07:00
|
|
|
Icons.arrow_forward,
|
|
|
|
color: candyApple,
|
2019-04-24 00:27:23 -07:00
|
|
|
),
|
2019-07-27 15:34:01 -07:00
|
|
|
iconSize: 60.0,
|
2019-06-27 17:29:40 -07:00
|
|
|
onPressed: () {
|
2019-07-27 15:34:01 -07:00
|
|
|
_showDBExportDialog();
|
2019-06-27 17:29:40 -07:00
|
|
|
},
|
|
|
|
),
|
2019-04-24 00:27:23 -07:00
|
|
|
),
|
2019-06-27 17:29:40 -07:00
|
|
|
],
|
2019-04-24 00:27:23 -07:00
|
|
|
),
|
2019-07-25 09:26:13 -07:00
|
|
|
),
|
|
|
|
Container(
|
|
|
|
padding: myBoxPadding,
|
|
|
|
decoration: myBoxDecoration(ivory),
|
2019-07-27 15:34:01 -07:00
|
|
|
child: Row(
|
|
|
|
children: [
|
|
|
|
Expanded(
|
|
|
|
flex: 2,
|
|
|
|
child: IconButton(
|
|
|
|
alignment: Alignment.center,
|
|
|
|
icon: Icon(
|
|
|
|
Icons.arrow_forward,
|
|
|
|
color: candyApple,
|
2019-07-25 09:26:13 -07:00
|
|
|
),
|
2019-07-27 15:34:01 -07:00
|
|
|
iconSize: 60.0,
|
|
|
|
onPressed: () {
|
|
|
|
_showDBImportDialog();
|
|
|
|
},
|
2019-07-25 09:26:13 -07:00
|
|
|
),
|
2019-07-27 15:34:01 -07:00
|
|
|
),
|
|
|
|
Expanded(
|
|
|
|
flex: 6,
|
|
|
|
child: Text(
|
|
|
|
'Import DataBase',
|
|
|
|
textAlign: TextAlign.center,
|
|
|
|
style: TextStyle(
|
|
|
|
height: textHeight,
|
|
|
|
fontSize: 20,
|
2019-07-25 09:26:13 -07:00
|
|
|
),
|
|
|
|
),
|
2019-07-27 15:34:01 -07:00
|
|
|
),
|
|
|
|
Expanded(
|
|
|
|
flex: 2,
|
|
|
|
child: IconButton(
|
|
|
|
alignment: Alignment.center,
|
|
|
|
icon: Icon(
|
|
|
|
Icons.arrow_back,
|
|
|
|
color: candyApple,
|
2019-07-25 09:26:13 -07:00
|
|
|
),
|
2019-07-27 15:34:01 -07:00
|
|
|
iconSize: 60.0,
|
|
|
|
onPressed: () {
|
|
|
|
_showDBImportDialog();
|
|
|
|
},
|
2019-07-25 09:26:13 -07:00
|
|
|
),
|
2019-07-27 15:34:01 -07:00
|
|
|
),
|
|
|
|
],
|
|
|
|
),
|
2019-07-25 09:26:13 -07:00
|
|
|
),
|
2019-04-24 00:27:23 -07:00
|
|
|
],
|
2019-06-27 17:29:40 -07:00
|
|
|
),
|
2019-04-24 00:27:23 -07:00
|
|
|
),
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
Future<void> updateState() async {
|
2019-06-27 17:29:40 -07:00
|
|
|
String _evServer = await getPreferenceElevationServer();
|
|
|
|
String _oWMK = await getPreferenceOpenWeatherMapApiKey();
|
2019-07-25 09:26:13 -07:00
|
|
|
String _dbEFNS = await getPreferenceDBExportFileName();
|
2019-06-27 17:29:40 -07:00
|
|
|
bool _useElev = await getPreferenceUseElevation();
|
|
|
|
bool _useWTHR = await getPreferenceUseWeather();
|
|
|
|
setState(() {
|
|
|
|
this.elevationServer = _evServer;
|
|
|
|
this.openWeatherMapKey = _oWMK;
|
|
|
|
this._useElevation = _useElev;
|
|
|
|
this._useWeather = _useWTHR;
|
|
|
|
this.shortOWMAK = _oWMK.substring(0, 5);
|
2019-07-25 09:26:13 -07:00
|
|
|
this._dbExportFileNameString = _dbEFNS;
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
void _updatedbExportFileName() {
|
|
|
|
String _dbEFNS = this._dbExportFileNameString;
|
|
|
|
setPreferenceDBExportFileName(_dbEFNS).then((bool committed) {
|
|
|
|
setState(() {
|
|
|
|
this._dbExportFileNameString = _dbEFNS;
|
|
|
|
});
|
2019-06-27 17:29:40 -07:00
|
|
|
});
|
2019-04-24 00:27:23 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
void _updateOpenWeatherMapApiKey() {
|
2019-06-27 17:29:40 -07:00
|
|
|
String _oWMK = _oWMKController.text;
|
|
|
|
if (_oWMK.length > 5) {
|
|
|
|
setPreferenceOpenWeatherMapApiKey(_oWMK).then((bool committed) {
|
|
|
|
if (_oWMK != this.openWeatherMapKey) {
|
|
|
|
setState(() {
|
|
|
|
this.openWeatherMapKey = _oWMK;
|
|
|
|
this.shortOWMAK = _oWMK.substring(0, 5);
|
2019-04-24 00:27:23 -07:00
|
|
|
});
|
|
|
|
}
|
|
|
|
});
|
2019-06-27 17:29:40 -07:00
|
|
|
Navigator.pop(context, 2);
|
2019-04-24 00:27:23 -07:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void _updateElevationServer() {
|
2019-06-27 17:29:40 -07:00
|
|
|
String _elevServer = _elevationServerController.text;
|
|
|
|
RegExp _urlValidator = RegExp(r'^http[s]?://.+$');
|
|
|
|
if (_urlValidator.hasMatch(_elevServer)) {
|
|
|
|
setPreferenceElevationServer(_elevServer).then((bool committed) {
|
|
|
|
if (_elevServer != this.elevationServer) {
|
|
|
|
setState(() {
|
|
|
|
this.elevationServer = _elevServer;
|
2019-04-24 00:27:23 -07:00
|
|
|
});
|
|
|
|
}
|
|
|
|
});
|
2019-06-27 17:29:40 -07:00
|
|
|
Navigator.pop(context, 1);
|
2019-04-24 00:27:23 -07:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-06-27 17:29:40 -07:00
|
|
|
Future<bool> _popBack() {
|
|
|
|
Navigator.pop(context, 3);
|
|
|
|
return Future.value(false);
|
|
|
|
}
|
2019-04-24 00:27:23 -07:00
|
|
|
}
|