flow updates

This commit is contained in:
JMARyA 2024-09-24 13:05:02 +02:00
parent 6fb2d62a05
commit cc78c3e1be
Signed by: jmarya
GPG key ID: 901B2ADDF27C2263

View file

@ -232,20 +232,25 @@ class _FlowInfoPageState extends State<FlowInfoPage> {
} }
} }
class CreateFlowPage extends StatelessWidget { class CreateFlowPage extends StatefulWidget {
final API.FlowInfo info; final API.FlowInfo info;
final Function refresh; final Function refresh;
const CreateFlowPage(this.info, this.refresh, {super.key});
@override
State<CreateFlowPage> createState() => _CreateFlowPageState();
}
class _CreateFlowPageState extends State<CreateFlowPage> {
List<API.Transaction> depends = []; List<API.Transaction> depends = [];
CreateFlowPage(this.info, this.refresh, {super.key});
void _create(BuildContext context) { void _create(BuildContext context) {
// todo : input handling
API API
.API() .API()
.startFlow(info.id, input: depends.map((x) => x.uuid).toList()) .startFlow(widget.info.id, input: depends.map((x) => x.uuid).toList())
.then((flowID) { .then((flowID) {
refresh(); widget.refresh();
API.API().getFlow(flowID).then((flow) { API.API().getFlow(flowID).then((flow) {
Navigator.of(context).pushReplacement( Navigator.of(context).pushReplacement(
MaterialPageRoute(builder: (context) => ActiveFlowPage(flow))); MaterialPageRoute(builder: (context) => ActiveFlowPage(flow)));
@ -261,7 +266,9 @@ class CreateFlowPage extends StatelessWidget {
builder: (context) { builder: (context) {
return TransactionSelectPage(transactions, onSelect: (t) { return TransactionSelectPage(transactions, onSelect: (t) {
if (!depends.contains(t)) { if (!depends.contains(t)) {
setState(() {
depends.add(t); depends.add(t);
});
} }
}, exclude: depends); }, exclude: depends);
}, },
@ -271,7 +278,7 @@ class CreateFlowPage extends StatelessWidget {
Widget buildInputSelection(BuildContext context) { Widget buildInputSelection(BuildContext context) {
return Column( return Column(
children: info.depends.map((x) { children: widget.info.depends.map((x) {
return ElevatedButton( return ElevatedButton(
onPressed: () { onPressed: () {
selectDependItems(context, x); selectDependItems(context, x);
@ -283,7 +290,7 @@ class CreateFlowPage extends StatelessWidget {
@override @override
Widget build(BuildContext context) { Widget build(BuildContext context) {
return Scaffold( return Scaffold(
appBar: AppBar(title: Text("Create new ${info.name} Flow")), appBar: AppBar(title: Text("Create new ${widget.info.name} Flow")),
body: Column( body: Column(
children: [ children: [
buildInputSelection(context), buildInputSelection(context),
@ -344,15 +351,24 @@ class TransactionSelectPage extends StatelessWidget {
} }
class ActiveFlowPage extends StatelessWidget { class ActiveFlowPage extends StatelessWidget {
late API.Flow flow; final API.Flow flow;
ActiveFlowPage(this.flow); const ActiveFlowPage(this.flow, {super.key});
@override @override
Widget build(BuildContext context) { Widget build(BuildContext context) {
return Scaffold( return Scaffold(
body: Column( body: Column(
children: [], children: [
Text("ID: ${flow.id}"),
Text("Started since: ${tsFormat(flow.started)}"),
...flow.input!.map((x) => Text("Input: $x")).toList(),
if (flow.done != null) ...[
Text("Ended: ${tsFormat(flow.done!.ended)}"),
if (flow.done!.next != null) Text("Next: ${flow.done!.next!}"),
...flow.done!.produced!.map((x) => Text("Produced: $x")).toList(),
]
],
)); ));
} }
} }