cdb_ui/lib/pages/flow.dart

232 lines
6.2 KiB
Dart
Raw Normal View History

2024-09-20 06:52:56 +00:00
import 'package:cdb_ui/api.dart' as API;
2024-09-23 09:35:37 +00:00
import 'package:cdb_ui/pages/expandable_list.dart';
2024-09-19 06:46:48 +00:00
import 'package:flutter/material.dart';
2024-09-23 09:35:37 +00:00
class FlowsPage extends StatefulWidget {
2024-09-19 06:46:48 +00:00
const FlowsPage({super.key});
2024-09-23 09:35:37 +00:00
@override
State<FlowsPage> createState() => _FlowsPageState();
}
class _FlowsPageState extends State<FlowsPage> {
int tabSelection = 0;
Map<String, API.FlowInfo>? flowInfos;
@override
void initState() {
super.initState();
API.API().getFlows().then(
(value) {
setState(() {
flowInfos = value;
});
},
);
}
Widget flowTile(BuildContext context, API.FlowInfo x) {
return ListTile(
title: Text(x.name),
onTap: () {
Navigator.of(context).push(MaterialPageRoute(
builder: (context) => FlowInfoPage(x),
));
},
);
}
2024-09-23 09:43:34 +00:00
Widget listFlowInfoByActive(
BuildContext context, Map<String, API.FlowInfo> infos) {
return FutureBuilder(future: () async {
var included = [];
for (var key in infos.keys) {
var active = await API.API().getActiveFlowsOf(key);
if (active.isNotEmpty) {
included.add(infos[key]);
}
}
return included;
}(), builder: (context, snapshot) {
if (!snapshot.hasData) {
return const CircularProgressIndicator();
}
var included = snapshot.data!;
return ListView(
children: included.map((x) => flowTile(context, x)).toList());
});
}
2024-09-23 08:31:40 +00:00
Widget listAllFlowInfos(
BuildContext context, Map<String, API.FlowInfo> infos) {
return ListView(
children: infos.values.map((x) {
2024-09-23 09:35:37 +00:00
return flowTile(context, x);
2024-09-23 08:31:40 +00:00
}).toList());
}
2024-09-23 09:35:37 +00:00
Widget listFlowInfoByProduced(
BuildContext context, Map<String, API.FlowInfo> infos) {
Map<String, List<API.FlowInfo>> producedMapping = {};
for (var f in infos.values) {
for (var produces in f.produces ?? []) {
var item = API.itemVariant(produces).$1;
producedMapping.putIfAbsent(item, () {
return [];
});
producedMapping[item]!.add(f);
}
}
List<ExpandableListItem> items = [];
for (var key in producedMapping.keys) {
var flows = Column(
children: producedMapping[key]!.map((x) {
return flowTile(context, x);
}).toList());
2024-09-23 12:40:25 +00:00
items.add(
ExpandableListItem(body: flows, header: ListTile(title: Text(key))));
2024-09-23 09:35:37 +00:00
}
return ExpandableList(items);
}
Widget listFlowInfoByDependant(
BuildContext context, Map<String, API.FlowInfo> infos) {
Map<String, List<API.FlowInfo>> dependsMapping = {};
for (var f in infos.values) {
for (var produces in f.depends) {
var item = API.itemVariant(produces).$1;
// todo : add only if item is in inventory
dependsMapping.putIfAbsent(item, () {
return [];
});
dependsMapping[item]!.add(f);
}
}
List<ExpandableListItem> items = [];
for (var key in dependsMapping.keys) {
var flows = Column(
children: dependsMapping[key]!.map((x) {
return flowTile(context, x);
}).toList());
2024-09-23 12:40:25 +00:00
items.add(
ExpandableListItem(body: flows, header: ListTile(title: Text(key))));
2024-09-23 09:35:37 +00:00
}
return ExpandableList(items);
}
2024-09-19 06:46:48 +00:00
@override
Widget build(BuildContext context) {
2024-09-23 09:35:37 +00:00
if (flowInfos == null) {
return const CircularProgressIndicator();
}
2024-09-23 11:57:08 +00:00
return DefaultTabController(
length: 4,
child: Scaffold(
appBar: AppBar(
title: const Text("Flows"),
bottom: TabBar(
tabs: const [
Tab(text: "All"),
Tab(text: "Produces"),
Tab(text: "Depends"),
Tab(text: "Active")
],
onTap: (value) {
setState(() {
tabSelection = value;
});
},
)),
body: switch (tabSelection) {
0 => listAllFlowInfos(context, flowInfos!),
1 => listFlowInfoByProduced(context, flowInfos!),
2 => listFlowInfoByDependant(context, flowInfos!),
3 => listFlowInfoByActive(context, flowInfos!),
_ => const Text("..."),
}));
2024-09-19 06:46:48 +00:00
}
}
2024-09-23 09:35:37 +00:00
class FlowInfoPage extends StatelessWidget {
2024-09-20 06:52:56 +00:00
final API.FlowInfo info;
2024-09-19 06:46:48 +00:00
2024-09-23 09:35:37 +00:00
const FlowInfoPage(this.info, {super.key});
2024-09-19 06:46:48 +00:00
@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: [],
));
}
}