update
This commit is contained in:
parent
20bc5a9ae6
commit
3da48add7e
6 changed files with 98 additions and 87 deletions
|
@ -3,6 +3,7 @@ import 'package:http/http.dart' as http;
|
||||||
import 'package:shared_preferences/shared_preferences.dart';
|
import 'package:shared_preferences/shared_preferences.dart';
|
||||||
|
|
||||||
// todo : api errors
|
// todo : api errors
|
||||||
|
// todo : api caching
|
||||||
|
|
||||||
class API {
|
class API {
|
||||||
late SharedPreferences pref;
|
late SharedPreferences pref;
|
||||||
|
|
|
@ -20,9 +20,11 @@ class _EndFlowWithProduceState extends State<EndFlowWithProduce> {
|
||||||
List<Widget> ret = [];
|
List<Widget> ret = [];
|
||||||
|
|
||||||
for (var i in widget.info.produces!) {
|
for (var i in widget.info.produces!) {
|
||||||
ret.add(ElevatedButton(onPressed: () {
|
ret.add(ElevatedButton(
|
||||||
// todo : implement adding
|
onPressed: () {
|
||||||
}, child: Text("Produced $i")));
|
// todo : implement adding
|
||||||
|
},
|
||||||
|
child: Text("Produced $i")));
|
||||||
}
|
}
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
|
@ -38,14 +40,20 @@ class _EndFlowWithProduceState extends State<EndFlowWithProduce> {
|
||||||
Widget build(BuildContext context) {
|
Widget build(BuildContext context) {
|
||||||
// todo : show end screen with produce
|
// todo : show end screen with produce
|
||||||
return Scaffold(
|
return Scaffold(
|
||||||
appBar: AppBar(title: Text("End ${widget.info.name} Flow"),),
|
appBar: AppBar(
|
||||||
body: Column(children: [
|
title: Text("End ${widget.info.name} Flow"),
|
||||||
...addProduceButtons(),
|
),
|
||||||
const Divider(),
|
body: Column(
|
||||||
// todo : add produced list
|
children: [
|
||||||
const SizedBox(height: 10,),
|
...addProduceButtons(),
|
||||||
ElevatedButton(onPressed: _endFlow, child: const Text("End Flow"))
|
const Divider(),
|
||||||
],),
|
// todo : add produced list
|
||||||
|
const SizedBox(
|
||||||
|
height: 10,
|
||||||
|
),
|
||||||
|
ElevatedButton(onPressed: _endFlow, child: const Text("End Flow"))
|
||||||
|
],
|
||||||
|
),
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -158,4 +158,4 @@ class _FlowsPageState extends State<FlowsPage> {
|
||||||
_ => const Text("..."),
|
_ => const Text("..."),
|
||||||
}));
|
}));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -40,7 +40,7 @@ class _ItemViewState extends State<ItemView> {
|
||||||
fallbackWidth: 100,
|
fallbackWidth: 100,
|
||||||
fallbackHeight: 100,
|
fallbackHeight: 100,
|
||||||
),
|
),
|
||||||
), // todo
|
),
|
||||||
const SizedBox(
|
const SizedBox(
|
||||||
width: 16.0,
|
width: 16.0,
|
||||||
),
|
),
|
||||||
|
|
|
@ -178,10 +178,9 @@ class _SupplyPageState extends State<SupplyPage> {
|
||||||
|
|
||||||
// Note
|
// Note
|
||||||
TextFormField(
|
TextFormField(
|
||||||
decoration: const InputDecoration(labelText: 'Note'),
|
decoration: const InputDecoration(labelText: 'Note'),
|
||||||
controller: _noteController,
|
controller: _noteController,
|
||||||
maxLines: 5
|
maxLines: 5),
|
||||||
),
|
|
||||||
|
|
||||||
const SizedBox(height: 20),
|
const SizedBox(height: 20),
|
||||||
|
|
||||||
|
|
|
@ -23,78 +23,81 @@ class _TransactionPageState extends State<TransactionPage> {
|
||||||
title: Text(widget.transaction.item),
|
title: Text(widget.transaction.item),
|
||||||
actions: [
|
actions: [
|
||||||
IconButton(
|
IconButton(
|
||||||
onPressed: () async {
|
onPressed: () {
|
||||||
final locations = await API().getLocations();
|
API().getLocations().then((locations) {
|
||||||
List<String> locationList = locations.keys.toList();
|
List<String> locationList = locations.keys.toList();
|
||||||
String? selectedLocationID;
|
String? selectedLocationID;
|
||||||
|
|
||||||
await showDialog<int>(
|
showDialog(
|
||||||
context: context,
|
context: context,
|
||||||
builder: (BuildContext context) {
|
builder: (BuildContext context) {
|
||||||
return AlertDialog(
|
return AlertDialog(
|
||||||
title: const Text('Select Location'),
|
title: const Text('Move Transaction'),
|
||||||
content: Row(
|
content: Row(
|
||||||
mainAxisSize: MainAxisSize.min,
|
mainAxisSize: MainAxisSize.min,
|
||||||
children: [
|
children: [
|
||||||
DropdownButton<String>(
|
DropdownButton<String>(
|
||||||
value: selectedLocationID,
|
value: selectedLocationID,
|
||||||
onChanged: (value) {
|
onChanged: (value) {
|
||||||
selectedLocationID = value!;
|
selectedLocationID = value!;
|
||||||
API()
|
API()
|
||||||
.moveTransaction(widget.transaction.uuid,
|
.moveTransaction(widget.transaction.uuid,
|
||||||
selectedLocationID!)
|
selectedLocationID!)
|
||||||
.then((x) {
|
.then((x) {
|
||||||
Navigator.of(context).pop();
|
Navigator.of(context).pop();
|
||||||
});
|
|
||||||
|
|
||||||
setState(() {});
|
|
||||||
},
|
|
||||||
items: locationList
|
|
||||||
.map<DropdownMenuItem<String>>((locationID) {
|
|
||||||
return DropdownMenuItem<String>(
|
|
||||||
value: locationID,
|
|
||||||
child: Text(locations[locationID]!.name),
|
|
||||||
);
|
|
||||||
}).toList(),
|
|
||||||
),
|
|
||||||
IconButton(
|
|
||||||
onPressed: () {
|
|
||||||
API().getLocations().then((locations) {
|
|
||||||
QrBarCodeScannerDialog().getScannedQrBarCode(
|
|
||||||
context: context,
|
|
||||||
onCode: (code) {
|
|
||||||
// library is retarded
|
|
||||||
code = code!.replaceFirst(
|
|
||||||
"Code scanned = ", "");
|
|
||||||
if (!locations.containsKey(code)) {
|
|
||||||
ScaffoldMessenger.of(context)
|
|
||||||
.showSnackBar(
|
|
||||||
SnackBar(
|
|
||||||
content: Text(
|
|
||||||
'The location $code does not exist.')),
|
|
||||||
);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
API()
|
|
||||||
.moveTransaction(
|
|
||||||
widget.transaction.uuid,
|
|
||||||
selectedLocationID!)
|
|
||||||
.then(
|
|
||||||
(x) {
|
|
||||||
Navigator.of(context).pop();
|
|
||||||
},
|
|
||||||
);
|
|
||||||
});
|
|
||||||
});
|
});
|
||||||
|
|
||||||
setState(() {});
|
setState(() {});
|
||||||
},
|
},
|
||||||
icon: const Icon(Icons.qr_code))
|
items: locationList
|
||||||
],
|
.map<DropdownMenuItem<String>>((locationID) {
|
||||||
),
|
return DropdownMenuItem<String>(
|
||||||
);
|
value: locationID,
|
||||||
},
|
child: Text(locations[locationID]!.name),
|
||||||
);
|
);
|
||||||
|
}).toList(),
|
||||||
|
),
|
||||||
|
IconButton(
|
||||||
|
onPressed: () {
|
||||||
|
API().getLocations().then((locations) {
|
||||||
|
QrBarCodeScannerDialog()
|
||||||
|
.getScannedQrBarCode(
|
||||||
|
context: context,
|
||||||
|
onCode: (code) {
|
||||||
|
// library is retarded
|
||||||
|
code = code!.replaceFirst(
|
||||||
|
"Code scanned = ", "");
|
||||||
|
if (!locations
|
||||||
|
.containsKey(code)) {
|
||||||
|
ScaffoldMessenger.of(context)
|
||||||
|
.showSnackBar(
|
||||||
|
SnackBar(
|
||||||
|
content: Text(
|
||||||
|
'The location $code does not exist.')),
|
||||||
|
);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
API()
|
||||||
|
.moveTransaction(
|
||||||
|
widget.transaction.uuid,
|
||||||
|
selectedLocationID!)
|
||||||
|
.then(
|
||||||
|
(x) {
|
||||||
|
Navigator.of(context).pop();
|
||||||
|
},
|
||||||
|
);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
setState(() {});
|
||||||
|
},
|
||||||
|
icon: const Icon(Icons.qr_code))
|
||||||
|
],
|
||||||
|
),
|
||||||
|
);
|
||||||
|
},
|
||||||
|
);
|
||||||
|
});
|
||||||
},
|
},
|
||||||
icon: const Icon(Icons.move_up))
|
icon: const Icon(Icons.move_up))
|
||||||
],
|
],
|
||||||
|
@ -327,4 +330,4 @@ class TransactionSelectPage extends StatelessWidget {
|
||||||
.toList()),
|
.toList()),
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue