2024-09-20 06:52:56 +00:00
|
|
|
import 'package:cdb_ui/api.dart' as API;
|
2024-09-19 06:46:48 +00:00
|
|
|
import 'package:flutter/material.dart';
|
|
|
|
|
|
|
|
class FlowsPage extends StatelessWidget {
|
|
|
|
const FlowsPage({super.key});
|
|
|
|
|
2024-09-23 08:31:40 +00:00
|
|
|
Widget listAllFlowInfos(
|
|
|
|
BuildContext context, Map<String, API.FlowInfo> infos) {
|
|
|
|
return ListView(
|
|
|
|
children: infos.values.map((x) {
|
|
|
|
return ListTile(
|
|
|
|
title: Text(x.name),
|
|
|
|
onTap: () {
|
|
|
|
Navigator.of(context).push(MaterialPageRoute(
|
|
|
|
builder: (context) => FlowPage(x),
|
|
|
|
));
|
|
|
|
},
|
|
|
|
);
|
|
|
|
}).toList());
|
|
|
|
}
|
|
|
|
|
2024-09-19 06:46:48 +00:00
|
|
|
@override
|
|
|
|
Widget build(BuildContext context) {
|
2024-09-23 08:31:40 +00:00
|
|
|
// todo : flows (info) by item produced
|
2024-09-20 06:52:56 +00:00
|
|
|
// todo : list currently active
|
|
|
|
// todo : flows by item needed (show only avail)
|
2024-09-19 06:46:48 +00:00
|
|
|
return Scaffold(
|
|
|
|
appBar: AppBar(title: const Text("Flows")),
|
|
|
|
body: FutureBuilder(
|
2024-09-20 06:52:56 +00:00
|
|
|
future: API.API().getFlows(),
|
2024-09-19 06:46:48 +00:00
|
|
|
builder: (ctx, snap) {
|
|
|
|
if (!snap.hasData) {
|
|
|
|
return const CircularProgressIndicator();
|
|
|
|
}
|
|
|
|
|
|
|
|
var data = snap.data!;
|
|
|
|
|
2024-09-23 08:31:40 +00:00
|
|
|
return listAllFlowInfos(context, data);
|
2024-09-19 06:46:48 +00:00
|
|
|
}));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
class FlowPage extends StatelessWidget {
|
2024-09-20 06:52:56 +00:00
|
|
|
final API.FlowInfo info;
|
2024-09-19 06:46:48 +00:00
|
|
|
|
|
|
|
const FlowPage(this.info, {super.key});
|
|
|
|
|
|
|
|
@override
|
|
|
|
Widget build(BuildContext context) {
|
|
|
|
return Scaffold(
|
|
|
|
appBar: AppBar(title: Text(info.name)),
|
|
|
|
body: Column(
|
|
|
|
children: [
|
|
|
|
// todo : ui improve
|
|
|
|
if (info.next != null) Text("Next: ${info.next}"),
|
|
|
|
if (info.depends.isNotEmpty)
|
|
|
|
Row(
|
|
|
|
mainAxisAlignment: MainAxisAlignment.spaceEvenly,
|
|
|
|
children: [
|
|
|
|
const Text("Flow can use: "),
|
|
|
|
...info.depends.map((x) => Text(x)).toList(),
|
|
|
|
],
|
|
|
|
),
|
|
|
|
if (info.produces?.isNotEmpty ?? false)
|
|
|
|
Row(
|
|
|
|
mainAxisAlignment: MainAxisAlignment.spaceEvenly,
|
|
|
|
children: [
|
|
|
|
const Text("Flow can produce: "),
|
|
|
|
...info.produces!.map((x) => Text(x)).toList(),
|
|
|
|
],
|
|
|
|
),
|
|
|
|
const Divider(),
|
|
|
|
FutureBuilder(
|
2024-09-20 06:52:56 +00:00
|
|
|
future: API.API().getActiveFlowsOf(info.id),
|
2024-09-19 06:46:48 +00:00
|
|
|
builder: (context, snapshot) {
|
|
|
|
if (!snapshot.hasData) {
|
|
|
|
return const CircularProgressIndicator();
|
|
|
|
}
|
|
|
|
|
|
|
|
var data = snapshot.data!;
|
|
|
|
|
2024-09-20 06:52:56 +00:00
|
|
|
return ListView(
|
|
|
|
children: data
|
|
|
|
.map((x) => ListTile(
|
|
|
|
title: Text(x.id),
|
|
|
|
onTap: () =>
|
|
|
|
Navigator.of(context).push(MaterialPageRoute(
|
|
|
|
builder: (context) => ActiveFlowPage(x),
|
|
|
|
))))
|
|
|
|
.toList());
|
2024-09-19 06:46:48 +00:00
|
|
|
},
|
|
|
|
)
|
|
|
|
],
|
|
|
|
),
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
2024-09-20 06:52:56 +00:00
|
|
|
|
|
|
|
class ActiveFlowPage extends StatelessWidget {
|
|
|
|
late API.Flow flow;
|
|
|
|
|
|
|
|
ActiveFlowPage(this.flow);
|
|
|
|
|
|
|
|
@override
|
|
|
|
Widget build(BuildContext context) {
|
|
|
|
return Scaffold(
|
|
|
|
body: Column(
|
|
|
|
children: [],
|
|
|
|
));
|
|
|
|
}
|
|
|
|
}
|