2
0
mirror of https://github.com/inventree/inventree-app.git synced 2025-04-28 05:26:47 +00:00

Load preferences before opening server settings dialog

- This ensures the settings are loaded and ready to go

(cherry picked from commit cd72d474a626232d10a7f7ff08419a10038c2c08)
This commit is contained in:
Oliver Walters 2020-04-05 13:19:43 +10:00
parent 804ed72dc6
commit cb751a7432
2 changed files with 33 additions and 34 deletions

View File

@ -6,8 +6,12 @@ import 'preferences.dart';
class InvenTreeLoginSettingsWidget extends StatefulWidget {
final SharedPreferences _preferences;
InvenTreeLoginSettingsWidget(this._preferences) : super();
@override
_InvenTreeLoginSettingsState createState() => _InvenTreeLoginSettingsState();
_InvenTreeLoginSettingsState createState() => _InvenTreeLoginSettingsState(_preferences);
}
@ -15,9 +19,18 @@ class _InvenTreeLoginSettingsState extends State<InvenTreeLoginSettingsWidget> {
final GlobalKey<FormState> _formKey = new GlobalKey<FormState>();
String _addr;
String _user;
String _pass;
final SharedPreferences _preferences;
String _server = '';
String _username = '';
String _password = '';
_InvenTreeLoginSettingsState(this._preferences) : super() {
_server = _preferences.getString('server') ?? '';
_username = _preferences.getString('username') ?? '';
_password = _preferences.getString('password') ?? '';
}
String _validateServer(String value) {
@ -48,18 +61,11 @@ class _InvenTreeLoginSettingsState extends State<InvenTreeLoginSettingsWidget> {
return null;
}
@override
void initState() {
load();
}
@override
Widget build(BuildContext context) {
final Size screenSize = MediaQuery.of(context).size;
load();
return Scaffold(
appBar: AppBar(
title: Text("Login Settings"),
@ -70,32 +76,33 @@ class _InvenTreeLoginSettingsState extends State<InvenTreeLoginSettingsWidget> {
key: _formKey,
child: new ListView(
children: <Widget>[
Text("Server"),
Text("Server Address"),
new TextFormField(
initialValue: _addr,
initialValue: _server,
decoration: InputDecoration(
hintText: "127.0.0.1:8000",
labelText: "Server:Port",
),
validator: _validateServer,
onSaved: (String value) {
_addr = value;
_server = value;
},
),
Divider(),
Text("Login Details"),
TextFormField(
initialValue: _user,
initialValue: _username,
decoration: InputDecoration(
hintText: "Username",
labelText: "Username",
),
validator: _validateUsername,
onSaved: (String value) {
_user = value;
_username = value;
}
),
TextFormField(
initialValue: _pass,
initialValue: _password,
obscureText: true,
decoration: InputDecoration(
hintText: "Password",
@ -103,13 +110,13 @@ class _InvenTreeLoginSettingsState extends State<InvenTreeLoginSettingsWidget> {
),
validator: _validatePassword,
onSaved: (String value) {
_pass = value;
_password = value;
},
),
Container(
width: screenSize.width,
child: RaisedButton(
child: Text("Login"),
child: Text("Save"),
onPressed: this.save,
)
)
@ -120,23 +127,11 @@ class _InvenTreeLoginSettingsState extends State<InvenTreeLoginSettingsWidget> {
);
}
void load() async {
SharedPreferences prefs = await SharedPreferences.getInstance();
_addr = prefs.getString('server');
_user = prefs.getString('username');
_pass = prefs.getString('password');
// Refresh the widget
setState(() {
});
}
void save() async {
if (_formKey.currentState.validate()) {
_formKey.currentState.save();
await InvenTreeUserPreferences().saveLoginDetails(_addr, _user, _pass);
await InvenTreeUserPreferences().saveLoginDetails(_server, _username, _password);
}
}

View File

@ -1,4 +1,5 @@
import 'package:flutter/material.dart';
import 'package:shared_preferences/shared_preferences.dart';
import 'login_settings.dart';
@ -40,8 +41,11 @@ class _InvenTreeSettingsState extends State<InvenTreeSettingsWidget> {
);
}
void _editServerSettings() {
Navigator.push(context, MaterialPageRoute(builder: (context) => InvenTreeLoginSettingsWidget()));
void _editServerSettings() async {
var prefs = await SharedPreferences.getInstance();
Navigator.push(context, MaterialPageRoute(builder: (context) => InvenTreeLoginSettingsWidget(prefs)));
}
void _about() async {